C#中SqlCommand干什么用的 对本地或远程的SQL数据库进行各种操作的挺好用的,尤其是SqlDataAdapter 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 SqlDataAdapter 与SqlCommand是什么关系 这个好像不是C#的吧,是.net Framework的吧,差点理解错了SqlCommand和SqlDataAdapter的主要差别是后者可以更容易的将获取的数据交给数据集 SqlCommand是sql命令,执行后通过sqlDataAdapter返回填入DataSet好象是这样,错了别扁我! icecools说得没错!SqlDataAdapter 有不同的构造函数,SqlDataAdapter(SqlCommand);SqlDataAdapter(string,SqlConnection); SqlDataAdapter da=new SqlDataAdapter();da.SelectCommand=new SqlCommand();da.SelectCommand.CommandText=strSql;da.SelectCommand.CommandTimeout=60;da.SelectCommand.Connection=myConn;da.SelectCommand.Transaction=myTrans;myDataSet=new DataSet();da.Fill(myDataSet,TableName); SqlCommand myCmd=new SqlCommand(strSql,myConn);myCmd.CommandType=CommandType.Text;myCmd.CommandTimeout=60;myCmd.Transaction=myTrans;intAffectedRows=myCmd.ExecuteNonQuery(); 其中myConn是连接对象,myTrans是事务对象,strSql是SQL语句,第一个例子通常是执行有返回数据集的查询如SELECT语句第二个例子通常是执行INSERT、UPDATE、DELETE语句。 在ADO.NET的DataAdapter其实是由很多个Command组成的。如SelectCommand,DeleteCommand,InsertCommand,UpdateCommand。 每一个Command都是一个独立的Command对象。也就是都有自己的Connection和CommandText。 DataAdapter的所有工作都会落实到一个Command上,比如查询就用SelectCommand。如果SelectCommand没有配置好,就不能执行这个工作。 相应的,如果要执行Update方法,就必须配置好UpdateCommand。而我们通常的定义中(如:OleDbDataAdapter da=new OleDbDataAdapter("Select * From Authors",conn);)都只是配置了SelectCommand,所以这时DataAdapter只能执行查询工作,而不能执行Update。 要让DataAdapter执行Update,当然就必须配置好UpdateCommand。但是这个Command的CommandText相当复杂(如果有N个字段的话,就有2*N+1个参数),如果要我们手工去配置,那简直就是不可能的。所以.NET为我们提供那一个自动配置其Command的工具CommandBuilder。用这个Class,我们就能把DataAdapter的所有Command配置好,从而使它能执行这些操作。 CommandBuilder也有两种:OleDbCommandBuilder和SqlCommandBuilder。分别对应OleDb和SQL Server。 使用C#解析XML文件,十万火急(在线等啊!) c# TextBox选中问题。 求救vs2008 “工具”下没有“选项”这个 请问WPF如何实现图片切换动画呢?并可以在程序里控制动画的播放与停止 C# 时间 XML解析错误 今天给学生简单排课,想到用算法实现一下,很有趣!大家进来讨论! 关于在UI中显示多线程中进度或者事件的一些问题 怎样在folderbrowser中严整文件夹路径有效性?急 菜鸟关于修改数据的问题 C#中继承的问题 一段简单的程序,看看毛病在哪里,可能和名称空间有关。
SqlCommand和SqlDataAdapter的主要差别是后者可以更容易的将获取的数据交给数据集
好象是这样,错了别扁我!
SqlDataAdapter 有不同的构造函数,
SqlDataAdapter(SqlCommand);
SqlDataAdapter(string,SqlConnection);
da.SelectCommand=new SqlCommand();
da.SelectCommand.CommandText=strSql;
da.SelectCommand.CommandTimeout=60;
da.SelectCommand.Connection=myConn;
da.SelectCommand.Transaction=myTrans;
myDataSet=new DataSet();
da.Fill(myDataSet,TableName);
myCmd.CommandType=CommandType.Text;
myCmd.CommandTimeout=60;
myCmd.Transaction=myTrans;
intAffectedRows=myCmd.ExecuteNonQuery();
第一个例子通常是执行有返回数据集的查询如SELECT语句
第二个例子通常是执行INSERT、UPDATE、DELETE语句。
每一个Command都是一个独立的Command对象。也就是都有自己的Connection和CommandText。
DataAdapter的所有工作都会落实到一个Command上,比如查询就用SelectCommand。如果SelectCommand没有配置好,就不能执行这个工作。
相应的,如果要执行Update方法,就必须配置好UpdateCommand。而我们通常的定义中(如:OleDbDataAdapter da=new OleDbDataAdapter("Select * From Authors",conn);)都只是配置了SelectCommand,所以这时DataAdapter只能执行查询工作,而不能执行Update。
要让DataAdapter执行Update,当然就必须配置好UpdateCommand。但是这个Command的CommandText相当复杂(如果有N个字段的话,就有2*N+1个参数),如果要我们手工去配置,那简直就是不可能的。所以.NET为我们提供那一个自动配置其Command的工具CommandBuilder。用这个Class,我们就能把DataAdapter的所有Command配置好,从而使它能执行这些操作。
CommandBuilder也有两种:OleDbCommandBuilder和SqlCommandBuilder。分别对应OleDb和SQL Server。