热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

深入解析C#中SqlCommand与SqlDataAdapter的核心差异与应用场景

本文深入探讨了C#中`SqlCommand`和`SqlDataAdapter`的核心差异及其应用场景。`SqlCommand`主要用于执行单一的SQL命令,并通过`DataReader`获取结果,具有较高的执行效率,但灵活性较低。相比之下,`SqlDataAdapter`则适用于复杂的数据操作,通过`DataSet`提供了更多的数据处理功能,如数据填充、更新和批量操作,更适合需要频繁数据交互的场景。

SqlCommand对应DateReader,SqlDataAdapter对应DataSet

SqlCommand的执行效率比较高,但不灵活,功能也有限

SqlDataAdapter的效率要低点,它是连接的,可随时更新数据,功能强大


        SqlCommand是C#中与Sql数据库打交道的对象,几乎所有的Sql数据库操作都需要使用该对象来实现,但其功能有限,只是简单的实现了与Sql数据库的接口而已。

        SqlDataAdapter是一个功能强大的SqL数据适配器,也用于操作Sql数据库,但它的操作都要通过SqlCommand来实现(有一个属性对象的类型就是SqlCommand),也就是说,可以把SqlDataAdapter看作是一个把一些特殊功能封装了、增强了的SqlCommand!

        Sqladapter是和dataset打交道的,Sqlcommand不能直接与dataset打交道,要通过Sqladapter。

        Sqladapter的定义是基于Sqlcommand的,当然也可以之间在定义Sqladapter的时候写入sql语句和connection对象 。

SqlDataAdapter对象

一、特点介绍

1、表示用于填充 DataSet 和更新 SQL Server 数据库的一组数据命令和一个数据库连接。
2、在SqlDataAdapter和DataSet之间没有直接连接。当完成SqlDataAdpater.Fill(DataSet)调用后,两个对象之间就没有连接了。

二、使用介绍

1、创建SqlDataAdapter

string sqlstr = "Server=localhost;UserId=root;Password=68331;Database=CarSYS;pooling=false;CharSet=utf8;port=3306";//声明一个字符串用来存放连接数据库的信息MySqlConnection con = new MySqlConnection(sqlstr);//创建一个SqlConnection对象con.Open();string strSQL=“Select * from Customers”;SqlCommand cmd = new SqlCommand(strSQL,cn);SqlDataAdapter da = new SqlDataAdapter();da.SelectCommand = cmd;

2、SqlDataAdapter构造函数

(1)、

string strConn = “Provider=.....”;string strSQL = “select * from Customers”;SqlDataAdapter da = new SqlDataAdapter(strSQL,strConn);

(2)、

string strConn = “Provider=.....”;SqlConnection cn = new SqlConnection(strConn);SqlDataAdapter da = new SqlDataAdapter(“select * from Customers”,cn);

(3)、

string strConn = “Provider=.....”;string strSQL = “select * from Customers”;SqlConnection cn = new SqlConnection(strConn);SqlCommand cmd = new SqlCommand(strSQL,cn);SqlDataAdapter da = new SqlDataAdapter(cmd);

3、从查询中获取结果

①使用Fill方法

SqlDataAdapter da = new SqlDataAdapter(strSQL,strConn);DataSet ds = new DataSet();da.Fill(ds); //这里ds中的表名为Table

②使用Fill方法创建DataTable对象和DataColumn对象

SqlDataAdapter da=new SqlDataAdapter(strSQL,strConn);
da.TableMapping.Add(“Table”,“Customers”);
DataSet ds=new DataSet();
da.Fill(ds);

③使用重载Fill方法

SqlDataAdapter.Fill(DataSet,“Customers”);SqlDataAdapter.Fill(DataTable);SqlDataAdapter.Fill(DataSet,intStartRecord,intNumRecords,“TableName”);

 ④开放和关闭连接

        如果调用了一个SqlDataAdapter对象的Fill方法,而SelectCommand属性的Connection关闭了,那么SqlDataAdapter就会开放一个连接,然后提交查询、获取结果、最后关闭连接。如果在调用前开放了Connection,那么操作之后仍然保持开放。

SqlDataAdapter daCustomers,daOrders;daCustomers=new SqlDataAdapter(“Select * fromCustomers”,cn);daOrders=new SqlDataAdapter(“Select * from Orders”,cn);DataSet ds=new DataSet();cn.Open();daCustomers.Fill(ds);daOrders.Fill(ds);cn.Close();

⑤多次调用Fill方法
    刷新DataSet中的数据,最简单的解决方法就是清空DataSet(或DataTable),然后再次调用DataAdapter对象的Fill方法。    

三、属性方法事件介绍 

 1、属性

①AcceptChangeDuringFill:确定由DataAdapter所获取的行的RowState(默认为True)。
②DeleteCommand:获取或设置一个 Transact-SQL 语句或存储过程,以从数据集删除记录。
③InsertCommand:获取或设置一个 Transact-SQL 语句或存储过程,以在数据源中插入新记录。
④SelectCommand:获取或设置一个 Transact-SQL 语句或存储过程,用于在数据源中选择记录。
⑤UpdateCommand:获取或设置一个 Transact-SQL 语句或存储过程,用于更新数据源中的记录。
⑥TableMappings:SqlDataAdapter用来将查询的结果映射到DataSet的信息集合。
⑦ContinueUpdate:控制SqlDataAdapter在遇到一个错误之后是否继续提交更改(默认为false)。

2、方法
①Fill:执行存储于SelectCommand中的查询,并将结果存储在DataTable中。
②FillSchema:为存储在SelectCommand中存储的查询获取架构信息。获取查询中的各列名称和数据类型。
③GetFillParameters:为SelectCommand获取一个包含着参数的数组。
④Update:向数据库提交存储在DataSet(或DataTable、DataRows)中的更改。该方法会返回一个整数值,其中包含着在数据存储中成功更新的行数。

3、事件
①FillError:当DataAdapter遇到填充DataSet或DataTable的一个错误时,该事件被触发。
②RowUpdated:向数据库提交一个修改的行之后被触发。
③RowUpdating:向数据库提交一个修改的行之前被触发。

 

SqlCommand对象

一、介绍

        SqlCommand对象允许你指定在数据库上执行的操作的类型。比如,你能够对数据库中的行数据执行select,insert,modify以及delete命令。SqlCommand对象能被用来支持断开连接数据管理的情况,但是在这节课我们将只单独使用SqlCommand对象。后面关于SqlDataAdapter的课程将解释如何使用断开数据实现应用程序。这节课将同时展示如何从数据库中返回一个单独的值,比如表中记录的数量。

二、创建SqlCommand对象

SqlCommand cmd = new SqlCommand("select CategoryName fromCategories", conn);

        上面一行是典型的实例化SqlCommand对象的代码。它使用一个string参数来保存你想要执行的命令以及一个关于SqlConnection对象的引用。SqlCommand具有重载形式,这些形式你将在以后的示例中看到。

三、查询数据

        当使用SQL的select命令,会得到一组数据集。为了和SqlCommand对象配合使用,你应该使用ExecuteReader方法,它返回一个SqlDataReader对象。我们将在后面的内容讨论SqlDataReader。下面的例子显示了如何使用SqlCommand对象来得到SqlDataReader对象:

// 1. Instantiate a new command with a query and connection
SqlCommand cmd = new SqlCommand("select CategoryName fromCategories", conn);
// 2. Call Execute reader to get query results
SqlDataReader rdr = cmd.ExecuteReader();

         在上面的示例中,我们通过传递命令字符串核连接对象到构造函数的方式实体化了SqlCommand对象。然后我们通过SqlCommand对象cmd调用ExecuteReader方法得到了SqlDataReader对象。
这些代码是表1中ReadData方法的一部分,我们将在后面集中介绍。

四、插入数据

        要对数据库插入数据,使用SqlCommand对象的ExecuteNonQuery方法。下面的代码显示了如何向数据库表插入数据:

string insertString = @"insert into Categories(CategoryName,Description)values ('Miscellaneous', 'Whatever doesn''t fit elsewhere')";
SqlCommand cmd = new SqlCommand(insertString, conn);
cmd.ExecuteNonQuery();

         SqlCommand的实例化过程与以前看到的有一些区别,但是基本一致。在构造函数的第一个字符串参数中是用的是插入字符串变量而不三字符串字面值。该变量在SqlCommand声明之前被声明了。
        注意在insertString文本中“doesn’’t”的两个单引号(’’)。这是将它转义为适当的单引号。
        另外一个需要注意的是我们显式指明了列:CategoryName和Description。列表中有一个主键名为CategoryID。我们忽略这列因为SQL Server将自动添加此字段。试图对主键比如CategoryID添加值会产生异常。
       为了执行此命令,我们简单的对SqlCommand实体cmd调用ExecuteNonQuery方法。
        这段代码是表1中InsertData方法的一部分,我们将在后面集中介绍。

五、更新数据

        ExecuteNonQuery方法同样用来更新数据。下面的代码显示了如何更新数据:

string updateString = @"update Categories set CategoryName = 'Other'where CategoryName = 'Miscellaneous'";
SqlCommand cmd = new SqlCommand(updateString);
cmd.Connection = conn;
cmd.ExecuteNonQuery();

六、删除数据

         你同样能够使用ExecuteNonQuery方法删除数据。下面的例子说明了如何使用EXecuteNonQuery方法删除数据库中的记录。 

string deleteString = @"delete from Categories where CategoryName ='Other'";
SqlCommand cmd = new SqlCommand();
cmd.CommandText = deleteString;
cmd.Connection = conn;
cmd.ExecuteNonQuery();

         这个示例使用了没有参数的SqlCommand构造函数。取而代之的是显式地设置了CommandText和SqlCommand对象的连接属性。
        我们同样能够使用SqlCommand构造函数在前面的两个重载形式——用来插入或者更新命令——得到相同的结果。它说明了在任何时候既能够改变命令文本又能够改变连接对象。
        ExecuteNonQuery方法调用将命令传递给数据库。

七、得到单一值

        某些时候你想从数据库中只取一个值,它可能是关于数据集的计数、和、平均值或者其他聚合数值。使用ExecuteReader方法并计算代码中的结果并不是做这些事情的有效方式。最好的选择就是让数据库能够执行并且只返回你所需要的单独的值。下面的示例说明了如何使用ExecuteScalar方法来实现:

SqlCommand cmd = new SqlCommand("select count(*) from Categories",conn);int count = (int)cmd.ExecuteScalar();

八、总结

        SqlCommand对象允许你擦许并对数据库传送命令。它含有针对不同的命令而特定的方法。ExecuteReader方法返回SqlDataReader对象来现实查询的结果。对于insert,update以及delete这些SQL命令,使用ExecuteNonQuery方法。如果你只需要查询的单独聚集值,ExecuteScalar方法是最好的选择

 

SqlDataAdapter和SqlCommand对比分析

一、SqlDataAdapter和DateSet

原理:DateSet是数据的内存驻留表示形式,它提供了独立于数据源的一致关系编程模型;从某种程度上说DateSet就是一个不可视的数据库。但真正与数据源打交道的是SqlDataAdapter,包括从数据源填充数据集和从数据集更新数据源。SqlDataAdapter使用Fill()方法将检索的数据填充到 DateSet。

流程:IE——GridView——DataSet——SqlDataAdapter——SQL数据库

public void BindGrid()
{SqlDataAdapter myAdp = new SqlDataAdapter("select * fromUserAdmin order by UserId desc", conn);DataSet ds = new DataSet();myAdp.Fill(ds, "Authors");//Label1.Text = ds.Tables[0].Rows.Count.ToString(); //得到共有多少条记录;GridView1.DataSource =ds.Tables["Authors"].DefaultView;GridView1.DataBind();
}

二、SqlCommand和SqlDataReade

原理:SqlCommand通过ExecuteReader()方法将得到的数据给SqlDataReade对象。

SqlDataReade逐行将从数据源获得的数据放进缓冲区进行处理。

优点:SqlDataReade执行速度快,提高应用程序性能。

优点原因:一旦数据可用,SqlDataReade就会立即检索该数据,而不是等待返回查询的全部结果;默认情况下,一次只在缓冲区存储一行,从而降低系统开销。

缺点:使用不灵活。

流程:IE——SqlDataReade——SqlCommand——SQL数据库

注:每次使用完SqlDataReade对象后一定要调用Close()方法将其关闭,因SqlDataReader对象以独占的方式使用Connection。

SqlCommand myconn = new SqlCommand("select * fromv_economy2_comidd where eid=" + Request.QueryString["eid"] +"", conn);
conn.Open();
SqlDataReader rd = myconn.ExecuteReader();
rd.Read();
Lbyear1.Text = rd["year1"].ToString();
Lbmonth1.Text = rd["month1"].ToString();
Lbcom_name.Text = rd["com_name"].ToString();
rd.Close();
conn.Close();

区别在于:

SqlDataAdapter:
        用于填充 DataSet 和更新 SQL 数据库的“一组”数据命令和“一个”数据库连接。
        SqlDataAdapter不但可以操作多个SQL命令,而且还可以操作一个SQL命令

        DataSet是关系型数据库的抽象,ADO.NET使用DataAdapter(意为数据适配器)作为Dataset和数据源之间的桥梁;DataAdapter 提供了Fill()方法从数据库中获取数据并生成DataSet。

SqlCommand:

        对 SQL 数据库执行的“一个”SQL语句或存储过程。SqlCommand只能操作一个SQL命令。

 

        个人觉得SqlCommand用来更新少量数据时比较合适,速度快,使用方便。他是执行sql语句查询的。
SqlDataAdapter用于把数据放到DataSet中,集中修改、删除后,通过Update把整个DataSet再提交回给数据库进行处理

 

 

        DataSet是离线的,所以SqlDataAdapter这个对象是连接DataSet和数据库的桥梁,所有对DataSet的操作(填充,更新等)都要通过他 ado.net数据访问有两种方式:

        1.离线--通过DataSet,然后离线增,删,改,最后通过SqlDataAdapter解 析到数据库中

        2.直接对数据库操作SqlCommand (Update,Insert,Delete) SqlCommand就是是命令了,可以用它来执行SQL命令 SqlDataAdapter就是数据适配器了,它是用于在数据源和数据集之间通讯的一组对象 SqlCommand对应DateReader SqlDataAdapter对应DataSet SqlCommand是C#中与Sql数据库打交道的对象,几乎所有的Sql数据库操作都需要使用该对象来实现,但其功能有限,只是简单的实现了与Sql数据库的接口而已; SqlDataAdapter是一个功能强大的SqL数据适配器,也用于操作Sql数据库,但它的操作都要通过SqlCommand来实现(有一个属性对象的类型就是SqlCommand),也就是说,可以把SqlDataAdapter看作是一个把一些特殊功能封装了、增强了的SqlCommand! SqlCommand与ADO时代的Command一样,SqlDataAdapter则是ADO.NET中的新事物,它配合DataSet来使用。其实,DataSet就像是驻留在内存中的小数据库,在DataSet中可以有多张DataTable,这些DataTable之间可以相互关联,就像在数据库中表关联一样!SqlDataAdapter的作用就是将数据从数据库中提取出来,放在DataSet中,当DataSet中的数据发生变化时,SqlDataAdapter再将数据库中的数据更新,以保证数据库中的数据和DataSet中的数据是一致的! 用微软顾问的话讲:DataAdapter就像是一把铁锹,它负责把数据从数据库铲到DataSet中,或者将数据从DataSet铲到数据库中!

 

 

 

https://www.cnblogs.com/jijm123/p/10260649.html

https://www.cnblogs.com/qiernonstop/p/3352710.html

 

 


推荐阅读
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 本文介绍了如何在C#中启动一个应用程序,并通过枚举窗口来获取其主窗口句柄。当使用Process类启动程序时,我们通常只能获得进程的句柄,而主窗口句柄可能为0。因此,我们需要使用API函数和回调机制来准确获取主窗口句柄。 ... [详细]
  • 本文探讨了 Objective-C 中的一些重要语法特性,包括 goto 语句、块(block)的使用、访问修饰符以及属性管理等。通过实例代码和详细解释,帮助开发者更好地理解和应用这些特性。 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
author-avatar
日落月出星不离_887
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有