Project requirements may dictate that conversion should be performed on field values.
For example, the Customer# field of the Customers table in the Northwind database may need to be converted to uppercase.
data:image/s3,"s3://crabby-images/6d9f5/6d9f50c1d1cf6c754f777a304951a8e2669635a6" alt="Customer# field value is uppercase. Customer# field value is uppercase."
However, there is no mechanism preventing users from saving lowercase letters in the field.
data:image/s3,"s3://crabby-images/44401/44401c10dc7118dfd4cab0a97b772731062dd6bc" alt="Customer# field has no validation to prevent lowercase letters. Customer# field has no validation to prevent lowercase letters."
Let’s create an SQL Business Rule to perform field value conversion.
Validate on Insert or Update
Start the Project Designer. In the Project Explorer, switch to the Controllers tab. Right-click on Customers / Business Rules node, and select New Business Rule.
data:image/s3,"s3://crabby-images/16f00/16f001f49a5778d4feb22e648feb70e18c75d367" alt="New Business Rule for Customers controller. New Business Rule for Customers controller."
Use the following properties:
Property | Value |
Command Name | Insert|Update |
Type | SQL |
Phase | Before |
Script | set @CustomerID = UPPER(@CustomerID)
|
Press OK to save the business rule. On the toolbar, press Browse.
Navigate to the Customers page, and edit a record. Insert some mixed-case letters in the Customer# field.
data:image/s3,"s3://crabby-images/fa611/fa611c762aeb741a46820ebd1e03ef36b2dee2e6" alt="Value of Customer# with lowercase letters. Value of Customer# with lowercase letters."
Save the record. The field value will be converted to uppercase.
data:image/s3,"s3://crabby-images/65f9b/65f9b2dd193a5597e312934c8772e6fadd331f7f" alt="Value of Customer# has been converted to uppercase. Value of Customer# has been converted to uppercase."
Validate on Calculate
You can also perform just-in-time value conversion, when the user moves focus away from the field.
Switch back to the Project Designer. In the Project Explorer, double-click on Customers / Business Rule / Insert|Update node.
data:image/s3,"s3://crabby-images/5bfb6/5bfb6b8d1f15443af29beae8db46323758b868a9" alt="InsertUpdate business rule for Customers controller. InsertUpdate business rule for Customers controller."
Change the Command Name property:
Property |
New Value |
Command Name |
Calculate |
Press OK to save the business rule. In order for the calculation to be performed, the field needs to cause a server request.
In the Project Explorer, double-click on Customers / Fields / CustomerID field node.
data:image/s3,"s3://crabby-images/992ab/992ab6d53e512e6322fad8000395d694bb100d83" alt="CustomerID field of Customers controller. CustomerID field of Customers controller."
Make the following changes:
Property |
New Value |
The value of this field is calculated by a business rule expression. |
True |
Context Fields |
CustomerID |
Press OK to save the field. On the toolbar, press Browse.
On the Customers page, edit a record. Insert mixed-case characters into the Customer# field.
data:image/s3,"s3://crabby-images/a2773/a27738dc5d9b04862fc59cf36f58726a73d5ae86" alt="Lower case characters inserted into CustomerID field. Lower case characters inserted into CustomerID field."
Press Tab on your keyboard or click on another field. The client library will convert the value in Customer# field into uppercase.
data:image/s3,"s3://crabby-images/9a308/9a308e7d05af323687a4d2860ecf9caeb9278d34" alt="CustomerID value converted to uppercase. CustomerID value converted to uppercase."
Expanding the Business Rule
The user may still click on the OK button and save the lowercase characters in the field. Therefore, you may need to combine both Insert|Update and Calculate command handling. The following Command Name will cover all possible methods of changing the field.
Property |
New Value |
Command Name |
Calculate|Insert|Update |
The same business logic can be implemented with the help of C#/Visual Basic Business Rules.