Master-detail relationships are present in all database web applications. Code On Time automatically generates two-level master-detail page layouts from your database.
You can also create three or more levels of master-detail relationships. For example, view the diagram from the Northwind database below. Order Details table references Orders table, which references Customers.
data:image/s3,"s3://crabby-images/54e50/54e501f5ea6af85ae54096a8c24ee36003f0cf19" alt="Customers, Orders, and Order Details table relationships in the Northwind database. Customers, Orders, and Order Details table relationships in the Northwind database."
Let’s create a master-detail page that allows the user to select the customer, the order, and then view the order details.
Create a Northwind web application. Start the Project Designer. In the Explorer, right-click on Home page node and choose New Page option.
data:image/s3,"s3://crabby-images/a9777/a9777df098dae09063aa3c413671c9fcf8cb9885" alt="'New Page' option in Code On Time Project Explorer. 'New Page' option in Code On Time Project Explorer."
Give this new page the following properties:
Property | Value |
Name | ThreeLevelMasterDetail |
Index | 1005 |
Title | Three-Level Master-Detail |
Path | Three-Level Master-Detail |
Style | Miscellaneous |
About This Page | This page will demo a three level master-detail data layout. |
Roles | (blank) |
Press OK to save the page.
Let’s add containers to hold the master and detail data views. In the Project Explorer, right-click on Three-Level Master-Detail page node, and select New Container.
data:image/s3,"s3://crabby-images/170fe/170fe48e2aed8b88a736044e21151f9af926d1d4" alt="'New Container' option for 'Three-Level Master-Detail' page in Project Explorer. 'New Container' option for 'Three-Level Master-Detail' page in Project Explorer."
Give this container the following properties:
Property | Value |
Flow | New Row |
Press OK to save the container. Create two more containers:
Property | Value |
Flow | New Row |
CSS Style Properties | padding-top:8px; |
Property | Value |
Flow | New Row |
CSS Style Properties | padding-top:8px; |
Let’s add a data view in each container. Right-click on Three-Level Master-Detail / c100 container node, and select New Data View option.
data:image/s3,"s3://crabby-images/a2713/a271319ca42bc2dca00ea625ada8f17bf735478a" alt="'New Data View' option for 'c100' container in the Project Explorer. 'New Data View' option for 'c100' container in the Project Explorer."
Give the new data view the following properties:
Property | Value |
Controller | Customers |
View | grid1 |
Text | Customers |
Show in Summary | True |
Page Size | 5 |
Press OK to save the data view. Right-click on Three-Level Master-Detail / c101 container node, and choose New Data View.
data:image/s3,"s3://crabby-images/06d6e/06d6e61621141dc75747fb3d0ade4a1deacb5dd1" alt="'New Data View' option for 'c101' container in the Project Explorer. 'New Data View' option for 'c101' container in the Project Explorer."
Give the data view the following properties. The Filter Field is a field in the child view that match the primary key of the master view.
Property | Value |
Controller | Orders |
View | grid1 |
Text | Orders |
Page Size | 5 |
Show View Selector | False |
Filter Source | dv100 |
Filter Field #1 | CustomerID |
Auto Hide | Container |
Press OK to save. Create one more data view by right-clicking on Three-Level Master-Detail / c102 container node and selecting New Data View.
data:image/s3,"s3://crabby-images/4aac7/4aac7cfe6c752897bec1725b02e5494db05e828f" alt="'New Data View' option for 'c102' container in the Project Explorer. 'New Data View' option for 'c102' container in the Project Explorer."
Use the following properties:
Property | Value |
Controller | OrderDetails |
View | grid1 |
Text | Details |
Page Size | 5 |
Show View Selector | False |
Filter Source | dv101 |
Filter Field #1 | OrderID |
Auto Hide | Container |
Press OK to save the data view. On the tool bar, press Browse to generate the application.
When it opens in your default browser, navigate to the Three-Level Master-Detail page.
data:image/s3,"s3://crabby-images/afc25/afc25a9de127aa4ca767d74be4350a1d6f051aee" alt="Select a Custom from the list on the Three-Level Master-Detail page. Select a Custom from the list on the Three-Level Master-Detail page."
First, select a Customer from the list. A child data view will open underneath, showing Orders.
data:image/s3,"s3://crabby-images/059ad/059ad313c6655338d885ac401b7b2872fb5191cb" alt="Upon selecting a Customer from the list, Orders data view will be displayed. Upon selecting a Customer from the list, Orders data view will be displayed."
Select an Order, and a list of Order Details will appear below.
data:image/s3,"s3://crabby-images/e05a4/e05a486e34672b5bf9ccda4bbe223a351ce9615b" alt="All three data views visible in the master-detail relationship on the Customers page. All three data views visible in the master-detail relationship on the Customers page."
data:image/s3,"s3://crabby-images/8adfe/8adfe8b9f88469a947c8a68cc56de13c79c4c24c" alt="All three data views visible in the master-detail relationship on the Customers page. All three data views visible in the master-detail relationship on the Customers page."