C#与数据库访问技术总结(十四)之DataAdapter对象
DataAdapter对象
DataAdapter对象主要用来承接Connection和DataSet对象。
DataSet对象只关心访问操作数据,而不关心自身包含的数据信息来自哪个Connection连接到的数据源,
而Connection对象只负责数据库连接而不关心结果集的表示。
所以,在ASP.NET的架构中使用DataAdapter对象来连接Connection和DataSet对象。
另外,DataAdapter对象能根据数据库里的表的字段结构,动态地塑造DataSet对象的数据结构。
DataAdapter对象的常用属性
DataAdapter对象的工作步骤一般有两种,
一种是通过Command对象执行SQL语句,将获得的结果集填充到DataSet对象中;
另一种是将DataSet里更新数据的结果返回到数据库中。
DataAdapter对象的常用属性形式为XXXCommand,用于描述和设置操作数据库。
使用DataAdapter对象,可以读取、添加、更新和删除数据源中的记录。
对于每种操作的执行方式,适配器支持以下4个属性,类型都是Command,分别用来管理数据操作的“增”、“删”、 “改”、“查”动作。
SelectCommand属性:该属性用来从数据库中检索数据。
InsertCommand属性:该属性用来向数据库中插入数据。
DeleteCommand属性:该属性用来删除数据库里的数据。
UpdateCommand属性:该属性用来更新数据库里的数据。
例如,以下代码能给DataAdapter对象的selectCommand属性赋值。
//连接字符串
SqlConnection conn;
//创建连接对象conn语句
//创建DataAdapter 对象
SqlDataAdapter da=new SqlDataAdapter;
//给DataAdapter对象SelectCommand属性赋值
da.SelectCommand =new SqlCommand(" select * from user ", conn);
//后继代码
同样,可以使用上述方式给其他的InsertCommand、DeleteCommand和UpdateCommand属性赋值。
当在代码里使用DataAdapter对象的SelectCommand属性获得数据表的连接数据时,
如果表中数据有主键,就可以使用CommandBuilder对象来自动为这个DataAdapter对象隐形地生成其他3个InsertCommand、DeleteCommand和UpdateCommand属性。
这样,在修改数据后,就可以直接调用Update方法将修改后的数据更新到数据库中,而不必再使用InsertCommand、DeleteCommand和UpdateCommand这3个属性来执行更新操作。
DataAdapter对象的常用方法
DataAdapter对象主要用来把数据源的数据填充到DataSet中,以及把DataSet里的数据更新到数据库,同样有SqlDataAdapter和OleDbAdapter两种对象。
它的常用方法有构造函数、填充或刷新DataSet的方法、将DataSet中的数据更新到数据库里的方法和释放资源的方法。
1.构造函数
不同类型的Provider使用不同的构造函数来完成DataAdapter对象的构造。对于SqlDataAdapter类,其构造函数说明如下表所示。
|
函数定义 |
参数说明 |
函数说明 |
|
SqlDataAdapter() |
不带参数 |
创建SqlDataAdapter对象 |
|
SqlDataAdapter(SqlCommand selectCommand |
selectCommand:指定新创建对象的SelectCommand属性 |
创建SqlDataAdapter对象。用参数selectCommand设置其Select Command属性 |
|
SqlDataAdapter(string selectCommandText, SqlConnection selectConnection) |
selectCommandText:指定新创建对象的SelectCommand属性值 selectConnection:指定连接对象 |
创建SqlDataAdapter对象。用参数selectCommandText设置其Select Command属性值,并设置其连接对象是selectConnection |
|
SqlDataAdapter(string selectCommandText,String selectConnectionString |
selectCommandText:指定新创建对象的SelectCommand属性值 selectConnectionString:指定新创建对象的连接字符串 |
创建SqlDataAdapter对象。将参数selectCommandText设置为Select Command属性值,其连接字符串是selectConnectionString |
O1eDbDataAdapter的构造函数类似SqlDataAdapter的构造函数,如下表2所述。
|
函数定义 |
参数说明 |
函数说明 |
|
OleDbDataAdapter() |
不带参数 |
创建OleDbDataAdapter对象 |
|
OleDbDataAdapter( OleDbCommand selectCommand) |
selectCommand:指定新创建对象的SelectCommand属性 |
创建OleDbDataAdapter对象。用参数selectCommand设置其SelectCommand属性 |
|
OleDbDataAdapter(string selectCommandText, OleDbConnection selectConnection) |
selectCommandText: 指定新创建对象的SelectCommand属性值 selectConnection:指定连接对象 |
创建SqlDataAdapter对象。用参数selectCommandText设置其SelectCommand属性值,并设置其连接对象是selectConnection |
|
OleDbDataAdapter(string selectCommandText,Stnng selectConnectionString) |
selectCommandText:指定新创建对象的SelectCommand属性值 selectConnectionString:指定新创建对象的连接字符串 |
创建OleDbDataAdapter对象。将参数selectCommandText设置为SelectCommand属性值,其连接字符串是selectConnectionString |
2.Fill类方法.
当调用Fill方法时,它将向数据存储区传输一条SQL SELECT语句。
该方法主要用来填充或刷新DataSet,返回值是影响DataSet的行数。
该方法的常用定义如表所示。
|
函数定义 |
参数说明 |
函数说明 |
|
int Fill(DataSet dataset) |
dataset:需要更新的DataSet |
根据匹配的数据源,添加或更新参数所指定的DataSet,返回值是影响的行数 |
|
int Fill(DataSet dataset, string srcTable) |
dataset:需要更新的DataSet srcTable:填充DataSet的dataTable名 |
根据dataTable名填充DataSet |
3.int Update(DaraSetdataSet)方法
当程序调用Update方法时,DataAdapter将检查参数DataSet每一行的RowState属性,根据RowState属性来检查DataSet里的每行是否改变和改变的类型,并依次执行所需的INSERT、UPDATE或DELETE语句,将改变提交到数据库中。
这个方法返回影响DataSet的行数。
更准确地说,Update方法会将更改解析回数据源,但自上次填充DataSet以来,其他客户端可能已修改了数据源中的数据。
若要使用当前数据刷新DataSet,应使用DataAdapter和Fill方法。
新行将添加到该表中,更新的信息将并入现有行。
Fill方法通过检查DataSet中行的主键值及SelectCommand返回的行来确定是要添加一个新行还是更新现有行。
如果Fill方法发现DataSet中某行的主键值与SelectCommand返回结果中某行的主键值相匹配,则它将用SelectCommand返回的行中的信息更新现有行,并将现有行的RowState设置为Unchanged。
如果SelectCommand返回的行所具有的主键值与DataSet中行的任何主键值都不匹配,则Fill方法将添加RowState为Unchanged的新行。
C#与数据库访问技术总结(十四)之DataAdapter对象的更多相关文章
- C#与数据库访问技术总结(十八)
ADO.NET 代码综合示例 前面已经介绍过OLE DB.NET和SQL Server.NET数据提供者可以用来连接不同的数据源. 以下代码不仅综合演示了使用ADO.NET的这两种数据提供者访问数据库 ...
- C#-数据库访问技术 ado.net——创建 数据库连接类 与 数据库操作方法 以及简单的数据的添加、删除、修改、查看
数据库访问技术 ado.net 将数据库中的数据,提取到内存中,展示给用户看还可以将内存中的数据写入数据库中去 并不是唯一的数据库访问技术,但是它是最底层的数据库访问技术 1.创建数据库,并设置主外键 ...
- C#与数据库访问技术总结(十六)之 DataSet对象
DataSet对象 DataSet对象可以用来存储从数据库查询到的数据结果,由于它在获得数据或更新数据后立即与数据库断开,所以程序员能用此高效地访问和操作数据库. 并且,由于DataSet对象具有离线 ...
- C#与数据库访问技术总结(十五)之 DataAdapter对象代码示例
DataAdapter对象代码示例 下面的代码将说明如何利用DataAdapter对象填充DataSet对象. private static string strConnect=" data ...
- c# 窗体开发4 数据库访问技术
ADO.NET的名称起源于ADO(ACTIVEX DATA OBJECTS) USING SYSTEM; USING SYSTEM.COLLECTIONS.GENERIC; USING SYSTEM. ...
- 数据库访问技术 odbc dao rdo uda jet oledb
一.UDA(UniversalDataAccess) 这是微软提供的通用数据访问策略.包括ADO.OLEDB和ODBC.它不光提供了数据库的访 问能力,对于其它的数据存储技术也同样支持,如目录服务.E ...
- C#与数据库访问技术总结(七)综合示例
综合示例 说明:前面介绍了那么多,光说不练假把式,还是做个实例吧. 表:首先你要准备一张表,这个自己准备吧.我们以学生表为例. 1.ExecuteScalar方法 ExecuteScalar方法执行返 ...
- 数据库访问优化漏斗法则- 四、减少数据库服务器CPU运算
数据库访问优化漏斗法则这个优化法则归纳为5个层次:1.减少数据访问次数(减少磁盘访问)2.返回更少数据(减少网络传输或磁盘访问)3.减少交互次数(减少网络传输)4.减少服务器CPU开销(减少CPU及内 ...
- C#与数据库访问技术总结(十七)
使用DataSet对象访问数据库 当对DataSet对象进行操作时,DataSet对象会产生副本,所以对DataSet里的数据进行编辑操作不会直接对数据库产生影响,而是将DataRow的状态设置为ad ...
随机推荐
- position:absolute、float、display:inline-block 区别
position: absolute会导致元素脱离文档流,被定位的元素等于在文档中不占据任何位置,在另一个层呈现,可以设置z-index.PS的图层效果就是position: absolute. fl ...
- 三天没有写题了,罪过!--Hash Table Start
(1)Island Perimeter 解题思路: 在矩阵上循环并记录岛(1)的个数;如果当前节点是岛,则检查其是否具有任何右邻居或下邻居,有的话邻居计数加1 ;岛的周长结果为islands * 4 ...
- 如何用Jquery实现 ,比如点击图片之后 ,该图片变成向下的箭头,再点击向下箭头的图片 又变成原始图片呢
<!DOCTYPE html><html><head><meta charset="utf-8" /><title>切换 ...
- (四) 一起学 Unix 环境高级编程(APUE) 之 系统数据文件和信息
. . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...
- Linux网络编程-SIGPIPE信号导致的程序退出问题
当客户端close关闭连接时,若server端接着发送数据,根据TCP协议的规定,server端会收到RST响应,当server端再次往客户端发送数据时,系统会发出一个SIGPIPE信号给server ...
- centos添加开机启动项目
centOS 配置开机自启动两种方式: 1.vi /etc/rc.d/rc.local 在此文件中加入启动的脚本 2.chkconfig 增加自己的脚本 --add --list --del 步骤: ...
- Ubuntu 14.04 (32位)上搭建Hadoop 2.5.1单机和伪分布式环境
引言 一直用的Ubuntu 32位系统(准备下次用Fedora,Ubuntu越来越不适合学习了),今天准备学习一下Hadoop,结果下载Apache官网上发布的最新的封装好的2.5.1版,配置完了根本 ...
- 使用dynamic动态设置属性值与反射设置属性值性能对比
static void Main(string[] args) { int times = 1000000; string value = "Dynamic VS Reflection&qu ...
- BIEE 11g 安装
1.安装oracle 创建字符集为AL32UTF8的实力MERIT sys密码merit 创建biee用户 create tablespace biee datafile 'D:\ORADATA\M ...
- 数据库操作(C#)
数据库在软件开发中发挥着举足轻重的作用,基本上所有的大项目都会用到数据库.ADO .Net是一组向.Net程序员公开数据访问服务的类,其主要分为数据提供程序(Data Provider)和数据集(Da ...