天天看点

SqlDataAdapter的用法

SqlDataAdapter是DataSet和 数据库的连接(桥接器),用于检索和保存数据,SqlDataAdaoter通过对数据源使用适当的Transact-SQL语句映射File(他作为填充DataSet的数据源中的数据)和Update(更改DataSet中的数据源)提供一种桥接方式,当SqlDataAdapter填充DataSet时,他为返回的数据创建必须的表和列

第一种方式(字符串查询)

string strCon =“uid=sa;pwd=123456;database=test;server=127.0.0.1”;

sql = “select * from table”;

SqlDataAdapter da = new SqlDataAdapter(sql,strCon);

DataSet ds = new DataSet();

da.Fill(ds,“临时虚拟表”);

dataGridView1.DataSource= ds.Tables[“临时虚拟表”];

第二种方式使用SqlConneclion对象来创建

string strConn=“uid=账号;pwd=密码;database=数据库;server=服务器”;//SQL Server链接字符串

SqlConnection conn=new SqlConnection(strConn);

string strSql=“SELECT * FROM 表名”;

SqlDataAdapter da = new SqlDataAdapter(strSql, conn);

DataSet ds=new DataSet();//创建DataSet实例

da.Fill(ds,“自定义虚拟表名”);//使用DataAdapter的Fill方法(填充),调用SELECT命令

第三种方式通过SqlCommand对象

string strConn=“uid=账号;pwd=密码;database=数据库;server=服务器”;//SQL Server链接字符串

SqlConnection connSql=new SqlConnection (strConn); //Sql链接类的实例化

connSql.Open ();//打开数据库

//使用SqlDataAdapter时没有必要从Connection.open()打开,

//SqlDataAdapter会自动打开关闭它。

string strSql = “SELECT * FROM 表名”; //要执行的SQL语句

SqlCommand cmd = new SqlCommand(strSql, connSql);

SqlDataAdapter da=new SqlDataAdapter(cmd); //创建DataAdapter数据适配器实例

DataSet ds=new DataSet();//创建DataSet实例

da.Fill(ds,“自定义虚拟表名”);//使用DataAdapter的Fill方法(填充),调用SELECT命令

connSql.Close();//关闭数据库

如果只需要执行SQL语句或SP,就没必要用到DataAdapter ,直接用SqlCommand的Execute系列方法就可以了。SqlDataadapter的作用是实现Dataset和DB之间的桥梁:比如将对DataSet的修改更新到数据库。

SqlDataAdapter的UpdateCommand的执行机制是:当调用SqlDataAdapter.Update()时,检查DataSet中的所有行,然后对每一个修改过的Row执行SqlDataAdapter.UpdateCommand ,也就是说如果未修改DataSet中的数据,SqlDataAdapter.UpdateCommand不会执行。

1、在使用Fill方式时,可以指定DataTable,而不是DataSet:

string strConn=“uid=账号;pwd=密码;database=数据库;server=服务器”;//SQL Server链接字符串

strSql=“SELECT * FROM 表名”;

SqlDataAdapter da = new SqlDataAdapter(strSql, strConn);

DataTable tbl=new DataTable( );

da.Fill(tbl);

注意打开和关闭连接的处理

在调用SqlCommand对象执行sql命令之前,需要保证与该对象关联的SqlConnection对象是打开的,否则SqlCommand的方法执行时将引发一个异常,但是我们在上面的代码中看到,SqlDataAdapter没有这样的要求。

如果调用SqlDataAdapter的Fill方法,并且其SelectCommand属性的SqlConnection是关闭状态,则SqlDataAdapter会自动打开它,然后提交查询,获取结果,最后关闭连接。如果在调用Fill方法前,SqlConnection是打开的,则查询执行完毕后,SqlConnection还将是打开的,也就是说SqlDataAdapter会保证SqlConnection的状态恢复到原来的情形

string strConn=“uid=账号;pwd=密码;database=数据库;server=服务器”;//SQL Server链接字符串

SqlConnection conn=new SqlConnection(strConn);

SqlDataAdapter daCustomers,daOrders;

strSql=“SELECT * FROM Customers”;

daCustomers = new SqlDataAdapter(strSql, conn);

strSql=“SELECT * FROM Orders”;

daOrders=new SqlDataAdapter(strSql, conn);

DataSet ds=new DataSet();

daCustomers.Fill(ds,“Customers”);

daOrders.Fill(ds,“Orders”);

以上代码会导致连接被打开和关闭两次,在调用Fill方法时各一次。为了避免打开和关闭SqlConnection对象,在调用SqlDataAdapter对象的Fill方法之前,我们可以先打开SqlConnection对象,如果希望之后关闭连接,我们可以再调用Close方法,就像这样: