批處理SQL語句與使用多表填充DataSet

本文介绍了如何通过批处理SQL语句提高数据库操作效率,并详细解释了使用多表填充DataSet的方法,包括如何通过TableMapping映射子表。

1. 批處理SQL語句
      很多的数据库支持合并或批處理语句,多个命令同时一次执行。例如SQL Server使用分号 ";" 分开多个命令语句。
合并多个命令成为一个命令降低了对服务器的访问次数,并且能够提高程序的性能。
      尽管这样做提高了处理性能,但会增加程序的复杂性,特别是在管理更新DataSet中的数据时。要降低复杂性,可能需要为DataSet中的DataTable创建DataAdapter。

2. 使用多表填充DataSet
      如果使用批處理的SQL语句来获取多表数据并填充DataSet,在Fill方法中使用第一個表的表名,對於子表,則依次在第一個表的名字後面遞增1,例如:
      
1 
2 SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM Customers; SELECT * FROM Orders;", myConnection);
3 DataSet ds = new DataSet();
4 da.Fill(ds, "Customers");
5 

      來自于Customs的數據在DataTable中的名字是“Customers”,來自Orders表的數據在DataTable中的名字是“Customers1”。
      在填充以後,可以很容易修改表 Customers1 的 TableName 屬性。然而,子表的填充將導致“Customers”被重新填充,但是“Orders”表會被忽略,而另外一個“Customers1”表會被創建。要改變這種狀況,就需要創建一個
TableMapping 來映射“Customers1”到“Orders”以及剩餘的表的映射。例如:
 
1 
2 SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM Customers; SELECT * FROM Orders;", myConnection);
3 da.TableMappings.Add("Customers1""Orders");
4 DataSet ds = new DataSet();
5 da.Fill(ds, "Customers");
6 

转载于:https://www.cnblogs.com/9999/archive/2009/08/08/1541630.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值