The CustomerID field from the Customers controller should have all values formatted in uppercase.
data:image/s3,"s3://crabby-images/3c42e/3c42edc069a1f05471513e9562646f6f8d477b30" alt="CustomerID field of the Customers controller. CustomerID field of the Customers controller."
Let’s create a business rule in C# or Visual Basic to convert all user input to uppercase.
Start the Project Designer. In the Project Explorer, switch to the Controllers tab and double-click on Customers controller node.
data:image/s3,"s3://crabby-images/690f5/690f5313ab2e36b30f7c910550a5023362e4894a" alt="Customers controller in the Project Explorer hierarchy. Customers controller in the Project Explorer hierarchy."
Change the Handler property:
Property | New Value |
Handler | CustomersRule |
Press OK to save the controller. In the Project Explorer, double-click on Customers / Fields / CustomerID field node.
data:image/s3,"s3://crabby-images/4c506/4c5063c7b87980aa750394cc8cd4e71088cb77ce" 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 |
Exit the designer and generate the application.
Click on the project name, and press Design. Visual Studio will open the project.
In the Solution Explorer, double-click on ~\App_Code\Rules\CustomersRule.cs(vb) file.
data:image/s3,"s3://crabby-images/23f14/23f14977e43691d4d11b70ee0c18344d7ea5f89d" alt="CustomersRule business rule file in the Solution Explorer. CustomersRule business rule file in the Solution Explorer."
Replace the sample code base with the following:
C#:
using System;
using System.Data;
using System.Collections.Generic;
using System.Linq;
using MyCompany.Data;
namespace MyCompany.Rules
{
public partial class CustomersRule : MyCompany.Data.BusinessRules
{
[ControllerAction("Customers", "Insert", ActionPhase.Before)]
[ControllerAction("Customers", "Update", ActionPhase.Before)]
[ControllerAction("Customers", "Calculate", ActionPhase.Execute)]
public void CalculateCustomerID(string customerID)
{
UpdateFieldValue("CustomerID", customerID.ToUpper());
}
}
}
Visual Basic:
Imports MyCompany.Data
Imports System
Imports System.Collections.Generic
Imports System.Data
Imports System.Linq
Namespace MyCompany.Rules
Partial Public Class CustomersRule
Inherits MyCompany.Data.BusinessRules
<ControllerAction("Customers", "Insert", ActionPhase.Before)>
<ControllerAction("Customers", "Update", ActionPhase.Before)>
<ControllerAction("Customers", "Calculate", ActionPhase.Execute)>
Public Sub CalculateCustomerID(ByVal customerID As String)
UpdateFieldValue("CustomerID", customerID.ToUpper())
End Sub
End Class
End Namespace
Save the file, and switch to the web application. Navigate to the Customers page, and create a new record. Type in lowercase letters for Customer# field.
data:image/s3,"s3://crabby-images/f06d5/f06d509fc32015ec9e45d9ea7b24d87731993d99" alt="CustomerID field with lowercase letters. CustomerID field with lowercase letters."
Press Tab or click on another area of the page. The text in Customer# will be converted to uppercase.
data:image/s3,"s3://crabby-images/cba72/cba72c175e459cd5a50658be89eacb1472fa5f4d" alt="The lowercase text in CustomerID field has been converted to uppercase. The lowercase text in CustomerID field has been converted to uppercase."
The same business logic can be implemented with the help of SQL Business Rules.