SqlCommand和SqlDataAdapter有什么区别

因为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铲到数据库中!
-----------------------------------------
SqlDataReader
只能顺序读,不能修改数据库
在程序没执行完之前一直保持连接
一次读出,可以放在DATASET里的。可以用来修改数据库


这个区别是比较明显的:

1,Command用来执行语句,只是单纯的执行,比如,新增,删除,修改,以及查找。

2,而DataAdapter则是数据适配器,用来填充数据集等容器(内部也实现了一些Command功能)。

所以,显而易见的,如果只是新增,删除,修改,以及简单的查找,则Command拥有极强的性能优势。

如果用来填充一些数据集容器(特指执行查询),则数据适配器是不二选择

Command一般用来做增删改的操作,当然也能够查询。

DataAdapter一般跟DataSet和DataTable一块进行查询操作。你可以把DataSet理解成临时的数据仓库,DataAdapter可以理解成在数据库与DataSet临时仓库之间的运输车。

如果数据量大的查询,如果返回行数多或者返回多个表,DataAdapter把经常要查询的数据临时保存在DataSet里,可以避免多次访问数据库,节省服务器的数据库连接资源。

如果不是特别大的查询,就可以直接用Command查询。毕竟货物少,给他一个单独的大仓库明显浪费。

可能比方不是很恰当,大概意思是这样的。

SqlCommand和SqlDataAdapter有什么区别,码迷,mamicode.com

时间: 2024-08-07 20:55:42

SqlCommand和SqlDataAdapter有什么区别的相关文章

C#中ExecuteReader、ExecuteNonQuery、ExecuteScalar、SqlDataReader、SqlDataAdapter的区别

ExecuteNonQuery()执行命令对象的SQL语句,返回一个int 类型的变量,返回数据库操作之后影响的行数.适合用来验证对数据库进行增删改的情况. 2.ExecuteScalar()也可以执行sql语句.如果SQL语句是Select查询,则仅仅返回查询结果集中第一行第一列,而忽略其他行和列.如果SQL语句不是Select查询,则这个返回结果没任何作用.(建议查询数据库时使用) 由于不知道sql语句到底是什么样的结构(有可能是int,有可能是Char等其它,)所以ExecuteScala

C#中ExecuteReader、ExecuteNonQuery、ExecuteScalar、SqlDataReader、SqlDataAdapter应该怎么用?

对于C#初学者来说,我们通常遇到ExecuteReader.ExecuteNonQuery.ExecuteScalar.SqlDataReader.SqlDataAdapter这些对象或者方法的时候就开始犯晕,不知道哪个对象适合用增删改,哪个对象适合查询的时候用,本人通过 网上搜索和个人的一些理解,整理了一下,有错误的地方希望大家能给出指正. 一.//数据库连接字符串    private readonly static string connectionString =      Config

SqlDataAdapter 用法详解

SqlCommand是sql命令,执行后通过sqlDataAdapter返回填入DataSet SqlDataAdapter   有不同的构造函数, SqlDataAdapter(SqlCommand): SqlDataAdapter(string,SqlConnection): SqlDataAdapter   da=new   SqlDataAdapter(); da.SelectCommand=new   SqlCommand(); da.SelectCommand.CommandText

我的设计模式总结

各位小牛大牛老鸟菜鸟们好,欢迎参观我的设计模式世界.这个世界我已经总结多年了,现在才刚刚成型.But I have a dream,梦想所有开发者都能一夜之间认清所有设计模式,还幻想以后大家认识设计模式时,必首先google本文,嘿嘿. 前辈同仁们已经总结过很多,至今首页上设计模式的文章仍然层出不穷.但我总认为,在GOF的23个设计模式提出多年了,该需要些变化和扩展了.特别适用于.NET(或Mono)的设计模式,好像没有系统的总结.新年伊始,推出这篇总结,我个人不喜欢人云亦云,对设计模式的整体,

C# ADO.NET编写简单的图书馆管理软件

使用软件: Microsoft SQL Server 2012 Microsoft Visual Studio 2012 本文地址: http://www.cnblogs.com/go2bed/ 参考资料: http://www.w3school.com.cn/ W3School http://baike.baidu.com/ 百度百科 http://blog.csdn.net/lvfeng19806001/article/details/8175153 WinForm控件缩写 及其他. 经验.

S2 第二本书 深入.NET平台和C#编程 总结 by天命

第一章 深入.NET框架 .NET框架 包含 CLR公共语言运行时 FCL框架类库 CLR(Common Language Runtime)公共语言运行时 CLS(Common Language Specific)公共语言规范 CTS(Common Type System)公共类型系统 FCL(Framework Class Library)框架类库 基本框架类(线程 ADO.NET XML类 文件IO类...... Web窗体 MVC WinForms ADO.NET SqlConnectio

.net数据库连接详解

ADO.NET与抽水的故事 ADO.NET是微软新一代.NET数据库的访问架构,ADO是ActiveX Data Objects的缩写.ADO.NET是数据库应用程序和数据源之间沟通的桥梁,主要提供一个面向对象的数据访问架构,用来开发数据库应用程序. 5.1.1  ADO.NET的定义 ADO.NET是为.NET框架而创建的,它提供对 Microsoft SQL Server.Oracle等数据源及通过OLE DB和XML公开的数据源的一致访问.应用程序可以使用ADO.NET来连接到这些数据源,

ADO.NET的基础

ADO.NET体系结构     Connection 提供和数据源的连接功能     Command 提供运行访问数据库命令,传送数据或修改数据的功能,例如运行SQL命令和存储过程等.   .NET Data Provider DataAdapter 是DataSet对象和数据源间的桥梁.DataAdapter使用4个Command对象来运行查询.新建.修改.删除的SQL命令,把数据加载到DataSet,或者把DataSet内的数据送回数据源.     DataReader 通过Command对

c# 轻量级 ORM 框架 之 DBHelper 实现 (三)

周末了比较清闲,把自己的orm框架整理了下,开源了. 已经做出来的东西通常感觉有些简单,一些新手或许听到"框架"一类的词觉得有些"高深",简单来说orm就是把ado的封装. 在介绍这个框架的第一篇博文,已经把DalBase介绍了一下设计思路,本篇的DBHelper对象也是给dalBase来用的,可以说框架的所有定义对象都是为了它. 这里起名叫DBHelper,因为我也是从写SQLHelper开始的,DBHelper只不过是所有类型对ado操作的各种方法的封装,所以本