Let’s add a Subtotal field to the order. This field will sum up the extended prices of all order details.
In the Project Explorer, switch to Controllers tab. Right-click on Orders / Fields, and press New Field.
data:image/s3,"s3://crabby-images/b6418/b6418be8fe1adb16e4a17bc0d9af72b2bef7c119" alt="New Field context menu option for Orders data controller. New Field context menu option for Orders data controller."
The new field’s settings will be:
Property | Value |
Field Name | Subtotal |
Type | Currency |
The value of this field is computed at run-time by SQL Expression | True |
SQL | select sum(UnitPrice*Quantity*(1-Discount))
from "Order Details"
where "Order Details".OrderID = Orders.OrderID
|
Label |
Subtotal |
Values of this field cannot be edited |
True |
Data Format String |
c |
Press OK to save the field.
Your application will incorporate this SQL Formula in the SELECT statements composed at runtime. This statement will look similar to:
select *,
(
select sum(UnitPrice*Quantity*(1-Discount)) from "Order Details"
where "Order Details".OrderID = Orders.OrderID
) Subtotal
from
"Orders" Orders
This is the output produced when the statement is executed in SQL Management Studio. The actual statement will look more complex, and may include user-defined sorting, filtering, and paging parameters.
data:image/s3,"s3://crabby-images/3baba/3babaa9fbbbd22e4301b25d9a9351eaa3d018c44" alt="Simplified statement of 'Subtotal' SQL Formula calculation in SQL Management Studio Simplified statement of 'Subtotal' SQL Formula calculation in SQL Management Studio"
We’ll need to bind this field to views, so that the end user can see the field value.
Drop Orders / Fields / Subtotal field node onto Orders / Views / grid1 node.
data:image/s3,"s3://crabby-images/40c2c/40c2c765a878d6254cb27a58a7ca412a55eec65c" alt="Subtotal data field node has been created in 'grid1'. Subtotal data field node has been created in 'grid1'."
Drop Subtotal field node onto Orders / Views / editForm1 node.
data:image/s3,"s3://crabby-images/e49ba/e49ba8c79dde621fb1c231c510ca3fc34e446f6d" alt="Subtotal data field node has been created in 'editForm1'. Subtotal data field node has been created in 'editForm1'."
Drop Subtotal field node onto Orders / Views / createForm1 view node.
data:image/s3,"s3://crabby-images/9fca1/9fca1e7e19aa2457591b49fc6c029d13b9bb6d30" alt="Subtotal data field node has been created in 'createForm1'. Subtotal data field node has been created in 'createForm1'."
Regenerate the application, and select any order on the Order Form page. You will see the Subtotal field showing the sum of extended prices.
data:image/s3,"s3://crabby-images/bb0b4/bb0b44cb2f525ad71d2f35cd69e10d008d2b2a4e" alt="Subtotal data field is present in editForm1 of Orders. Subtotal data field is present in editForm1 of Orders."