Retrieving Hierarchical Data into a DataSet
Số trang: 4
Loại file: pdf
Dung lượng: 23.03 KB
Lượt xem: 13
Lượt tải: 0
Xem trước 2 trang đầu tiên của tài liệu này:
Thông tin tài liệu:
[ Team LiB ] Recipe 2.1 Retrieving Hierarchical Data into a DataSet Problem You want to fill a DataSet with parent and related child data, even if the DataSet already has a schema that includes the relationship. Solution There are several techniques you can use to load parent and child data into a DataSet.
Nội dung trích xuất từ tài liệu:
Retrieving Hierarchical Data into a DataSet[ Team LiB ]Recipe 2.1 Retrieving Hierarchical Data into a DataSetProblemYou want to fill a DataSet with parent and related child data, even if the DataSet alreadyhas a schema that includes the relationship.SolutionThere are several techniques you can use to load parent and child data into a DataSet.The sample code contains three event handlers:Form.Load Sets up the sample by creating a DataSet with table schemas for both the Orders table and the Order Details table from Northwind and a DataRelation object relating these two tables. The default view of the parent table, Orders, is bound to a data grid on the form.Load DataSet Button.Click Starts by clearing the data from the DataSet and refreshing the data grid. DataAdapter objects are created for both the parent and the child table. The Orders and Order Details are then filled using data adapters in the sequence specified and enforcing constraints during the load as specified by the user.The C# code is shown in Example 2-1.Example 2-1. File: HierarchicalDataSetForm.cs// Namespaces, variables, and constantsusing System;using System.Configuration;using System.Windows.Forms;using System.Data;using System.Data.SqlClient;private DataSet ds;// . . .private void HierarchicalDataSetForm_Load(object sender, System.EventArgs e){ ds = new DataSet( ); // Get the schema for the Orders table. DataTable parentTable = new DataTable(Orders); SqlDataAdapter da = new SqlDataAdapter(SELECT * FROM Orders, ConfigurationSettings.AppSettings[Sql_ConnectString]); da.FillSchema(parentTable, SchemaType.Source); ds.Tables.Add(parentTable); // Get the schema for the Order Details table. DataTable childTable = new DataTable(Order Details); da = new SqlDataAdapter(SELECT * FROM [Order Details], ConfigurationSettings.AppSettings[Sql_ConnectString]); da.FillSchema(childTable, SchemaType.Source); ds.Tables.Add(childTable); // Add the relation between the tables. DataRelation dr = new DataRelation(Order_OrderDetails_Relation, parentTable.Columns[OrderID], childTable.Columns[OrderID]); ds.Relations.Add(dr); // Bind the default view of the Orders table with the grid. dataGrid.DataSource = parentTable.DefaultView;}private void loadDataSetButton_Click(object sender, System.EventArgs e){ // Remove all data from the DataSet and refresh the grid. ds.Clear( ); dataGrid.Refresh( ); // Create parent and child data adapters. SqlDataAdapter daParent = new SqlDataAdapter(SELECT * FROM Orders, ConfigurationSettings.AppSettings[Sql_ConnectString]); SqlDataAdapter daChild = new SqlDataAdapter( SELECT * FROM [Order Details], ConfigurationSettings.AppSettings[Sql_ConnectString]); // Enforce constraints as specified by user. ds.EnforceConstraints = (enforceConstraintsCheckBox.Checked); try { if (loadParentFirstRadioButton.Checked) { // Load parent data first. daParent.Fill(ds, Orders); daChild.Fill(ds, Order Details); } else { // Load child data first. daChild.Fill(ds, Order Details); daParent.Fill(ds, Orders); } } catch (Exception ex) { MessageBox.Show(ex.Message); return; } ds.EnforceConstraints = true;}DiscussionBy default, a DataRelation is created with constraints as in the example; however, anoverloaded constructor can override this behavior if necessary. If constraints are created,it is important that each record in the child table refers to a valid parent record, otherwisea ConstraintException is raised. Two techniques can be used to load parent and relatedchild data without error into a DataSet with a schema that includes data relations defined: • Load data from the parent tables before loading data from the child table. This ensures that each record in the child table refers to a valid parent record. • The EnforceConstraints property of the DataSet indicates whether constraint rules are followed when data is added to or modified in the DataSet. Turn constraints off by setting the EnforceConstraints property to false prior to loading the data and back to true once the data is loaded. With this approach the order in which the data is loaded is not important. If one or more constraints cannot be enforced when EnforceConstraints is set back to true, a ConstraintException will be raised and EnforceConstraints stay set to false.[ Team LiB ]
Nội dung trích xuất từ tài liệu:
Retrieving Hierarchical Data into a DataSet[ Team LiB ]Recipe 2.1 Retrieving Hierarchical Data into a DataSetProblemYou want to fill a DataSet with parent and related child data, even if the DataSet alreadyhas a schema that includes the relationship.SolutionThere are several techniques you can use to load parent and child data into a DataSet.The sample code contains three event handlers:Form.Load Sets up the sample by creating a DataSet with table schemas for both the Orders table and the Order Details table from Northwind and a DataRelation object relating these two tables. The default view of the parent table, Orders, is bound to a data grid on the form.Load DataSet Button.Click Starts by clearing the data from the DataSet and refreshing the data grid. DataAdapter objects are created for both the parent and the child table. The Orders and Order Details are then filled using data adapters in the sequence specified and enforcing constraints during the load as specified by the user.The C# code is shown in Example 2-1.Example 2-1. File: HierarchicalDataSetForm.cs// Namespaces, variables, and constantsusing System;using System.Configuration;using System.Windows.Forms;using System.Data;using System.Data.SqlClient;private DataSet ds;// . . .private void HierarchicalDataSetForm_Load(object sender, System.EventArgs e){ ds = new DataSet( ); // Get the schema for the Orders table. DataTable parentTable = new DataTable(Orders); SqlDataAdapter da = new SqlDataAdapter(SELECT * FROM Orders, ConfigurationSettings.AppSettings[Sql_ConnectString]); da.FillSchema(parentTable, SchemaType.Source); ds.Tables.Add(parentTable); // Get the schema for the Order Details table. DataTable childTable = new DataTable(Order Details); da = new SqlDataAdapter(SELECT * FROM [Order Details], ConfigurationSettings.AppSettings[Sql_ConnectString]); da.FillSchema(childTable, SchemaType.Source); ds.Tables.Add(childTable); // Add the relation between the tables. DataRelation dr = new DataRelation(Order_OrderDetails_Relation, parentTable.Columns[OrderID], childTable.Columns[OrderID]); ds.Relations.Add(dr); // Bind the default view of the Orders table with the grid. dataGrid.DataSource = parentTable.DefaultView;}private void loadDataSetButton_Click(object sender, System.EventArgs e){ // Remove all data from the DataSet and refresh the grid. ds.Clear( ); dataGrid.Refresh( ); // Create parent and child data adapters. SqlDataAdapter daParent = new SqlDataAdapter(SELECT * FROM Orders, ConfigurationSettings.AppSettings[Sql_ConnectString]); SqlDataAdapter daChild = new SqlDataAdapter( SELECT * FROM [Order Details], ConfigurationSettings.AppSettings[Sql_ConnectString]); // Enforce constraints as specified by user. ds.EnforceConstraints = (enforceConstraintsCheckBox.Checked); try { if (loadParentFirstRadioButton.Checked) { // Load parent data first. daParent.Fill(ds, Orders); daChild.Fill(ds, Order Details); } else { // Load child data first. daChild.Fill(ds, Order Details); daParent.Fill(ds, Orders); } } catch (Exception ex) { MessageBox.Show(ex.Message); return; } ds.EnforceConstraints = true;}DiscussionBy default, a DataRelation is created with constraints as in the example; however, anoverloaded constructor can override this behavior if necessary. If constraints are created,it is important that each record in the child table refers to a valid parent record, otherwisea ConstraintException is raised. Two techniques can be used to load parent and relatedchild data without error into a DataSet with a schema that includes data relations defined: • Load data from the parent tables before loading data from the child table. This ensures that each record in the child table refers to a valid parent record. • The EnforceConstraints property of the DataSet indicates whether constraint rules are followed when data is added to or modified in the DataSet. Turn constraints off by setting the EnforceConstraints property to false prior to loading the data and back to true once the data is loaded. With this approach the order in which the data is loaded is not important. If one or more constraints cannot be enforced when EnforceConstraints is set back to true, a ConstraintException will be raised and EnforceConstraints stay set to false.[ Team LiB ]
Tìm kiếm theo từ khóa liên quan:
công nghệ thông tin kỹ thuật lập trình Oreilly Ado Dot Net Cookbook Ebook-Lib Displaying an Image from a Database in a Web Forms ControlGợi ý tài liệu liên quan:
-
52 trang 417 1 0
-
Top 10 mẹo 'đơn giản nhưng hữu ích' trong nhiếp ảnh
11 trang 301 0 0 -
Báo cáo thực tập thực tế: Nghiên cứu và xây dựng website bằng Wordpress
24 trang 287 0 0 -
74 trang 283 0 0
-
96 trang 283 0 0
-
Đồ án tốt nghiệp: Xây dựng ứng dụng di động android quản lý khách hàng cắt tóc
81 trang 270 0 0 -
Tài liệu dạy học môn Tin học trong chương trình đào tạo trình độ cao đẳng
348 trang 268 1 0 -
EBay - Internet và câu chuyện thần kỳ: Phần 1
143 trang 260 0 0 -
Kỹ thuật lập trình trên Visual Basic 2005
148 trang 252 0 0 -
Tài liệu hướng dẫn sử dụng thư điện tử tài nguyên và môi trường
72 trang 251 0 0