C# 一次查询多表,填充DataSet并指定表名

lhrhi 原文 NET 一次查询多表,填充DataSet并指定表名(DataSet指定DataTable名称的技巧)

 

现实中的场景,有时可能需要一次查询数据库中表张。在使用SqlDataAdapter类的Fill方法填充DataSet, 同时指定填充到DataSet中DataTable表名。

例如设置成跟数据库一样的。可以通过SqlDataAdapter类的TableMappings属性实现。

 

SqlDataAdapter类的Fill方法填充DataSet中表名称,默认是Table, Table1, Table2……?

查询返回多张表

SqlConnection conn=new SqlConnection("server=.; database=DataBaseName; uid=sa; pwd=sa");  //数据库连接,可以自己定义。

string sql="SELECT * FROM User; SELECT * FROM Product; SELECT * FROM Article;";

SqlCommand cmd=new SqlCommand(sql,  conn);
SqlDataAdapter adapter=new SqlDataAdapter(cmd);

指定表名

TableMappings.Add方法,第一个参数是Fill DataSet时默认的表名,第二参数是指定的表名,可以根据需要自定义。

adapter.TableMappings.Add("Table", "User");
adapter.TableMappings.Add("Table1", "Product");
adapter.TableMappings.Add("Table2", "Article");

DataSet ds=new DataSet();
adapter.Fill(ds);  //被填充到DataSet中有三张表,分别是User,Product,Article

这样就可以了,

很容易将查询返回多个表(填充到DataSet 的表),和数据库里的表联系起来,方便在程序使用。

 

posted @ 2016-10-13 22:23  wenglabs  阅读(3909)  评论(2编辑  收藏  举报