It may be necessary for similar values to be copied from a lookup to a record.
When a simple copy operation is required, use the Copy property on the lookup field. For more complex copying operations, a business rule can be implemented. Let’s implement an SQL business rule to copy shipping information from a customer to an order in a sample Northwind web application.
Start the Project Designer. In the Project Explorer, switch to the Controllers tab and double-click on Orders / Fields / ShipName node.
data:image/s3,"s3://crabby-images/3a23a/3a23ad28b7bb88a0918307b2801cb2bb4c245e47" alt="ShipName field in the Orders controller in the Project Explorer. ShipName field in the Orders controller in the Project Explorer."
Change the following properties.
Property | Value |
The value of the field is calculated by a business rule expression | true |
Context Fields | CustomerID |
Press OK to save the field. Right-click on Orders / Business Rules node and press New Business Rule.
data:image/s3,"s3://crabby-images/bd524/bd52498670fff496fe7357096e45f9529b607e60" alt="New Business Rule context menu option in the Orders controller. New Business Rule context menu option in the Orders controller."
Give this rule the following properties.
Property | Value |
Type | SQL |
Command Name | New|Calculate |
Phase | Execute |
Script | if @CustomerID is not null
begin
select
@ShipName = ContactName,
@ShipAddress = Address,
@ShipCity = City,
@ShipRegion = Region,
@ShipPostalCode = PostalCode,
@ShipCountry = Country
from Customers
where
CustomerID = @CustomerID
end
|
Press OK to save the business rule. On the toolbar, press Browse to generate the web application.
Navigate to the Customers page. Select a customer from the list, and a list of orders will appear underneath. On the action bar, press New Orders. The shipping fields will be prepopulated with the customer shipping information.
data:image/s3,"s3://crabby-images/4deca/4deca9ec906430cfb6df4f1da976123baa029373" alt="New Orders form on the Customers page prepopulated with customer shipping information. New Orders form on the Customers page prepopulated with customer shipping information."
Navigate to the Orders page. On the action bar, press New Orders. The ship fields will be blank.
data:image/s3,"s3://crabby-images/bd80c/bd80cb5dbd9238010622cf952999126bfa880893" alt="New Orders form on the Orders page. Customer is not selected, and the shipping fields are blank. New Orders form on the Orders page. Customer is not selected, and the shipping fields are blank."
Use the Customer Company Name lookup to select a customer. The ship fields will automatically be populated with the values from the customer.
data:image/s3,"s3://crabby-images/dedd1/dedd16e17383b3e8c87f288c0fc154fcedf1331f" alt="A customer has been selected. Shipping information has been populated. A customer has been selected. Shipping information has been populated."