asp.net学习之ado.net(无连接模式中的DataAdapter)
原文:asp.net学习之ado.net(无连接模式中的DataAdapter)
在非连接模式下,主要讨论以下对象:DataAdapter。
DataAdpater的作用是在物理存储模式的数据和内存之间进行数据传递。DataTable是用在内存中表示数据库表。DataSet是内存中表示数据库(表、表关系的集合)。DataView是用于在内存中表示数据库视图。
DataAdapter对象在后台使用DataReader对象从数据库中获取数据;DataView对象来对数据进行过滤和排序;DataTable对象可以用来跟踪数据记录的改变情况,并决定是否接受或者拒绝这些改变。
1.DataAdapter对象
DataAdapter对象在物理数据库和内存数据表之间起桥梁的作用。一般用DataAdapter对象从数据库获取数据并装入DataTable对象中,也通过DataAdapter对象将DataTable对象中数据的修改写回到物理数据库。
例1: 一个简单的DataAdapter对象的使用
=== App_Code\DawnDataObject.cs ===
Codepublic class Movie_Disconnect{ private static readonly string _connectionstring; static Movie_Disconnect() { _connectionstring = WebConfigurationManager.ConnectionStrings["DawnEnterpriseDBConnectionString"]. ConnectionString.ToString(); } public DataTable GetAll() { // 初始化DataAdapter SqlDataAdapter dad = new SqlDataAdapter("Select Id,Title,Director from Movies", _connectionstring); // 初始化Table DataTable dt = new DataTable(); dad.Fill(dt); return dt; }}
=== showMovies.aspx
Code<asp:GridView ID="GridView1" runat="server" DataSourceID="ObjectDataSource1"></asp:GridView><asp:ObjectDataSource ID="ObjectDataSource1" TypeName="DawnDataObject.Movie_Disconnect" SelectMethod="GetAll" runat="server"></asp:ObjectDataSource>
2.DataAdapter的构造
在例1中,我们看到了如何构造一个SqlDataAdapter对象,并且使用Fill方法把数据表填到一个DataTable中。它看起来是像下面这样子的:
SqlDataAdapter dad = new SqlDataAdapter("Select Id,Title,Director from Movies", _connectionstring);DataTable dt = new DataTable();dad.Fill(dt);
在以上的例子中,看不到SqlConnection,SqlCommand对象的出象,其实,它们还是隐含存在的,这些对象被SqlDataAdapter对象调用了而已,就连SqlConnection对象的Open()方法的调用也由SqlDataAdapter对象来代劳了。
如果要显式使用SqlConnection,SqlCommand对象,可以像以下代码这样:
例2: SqlAdapter对象的另外构造方法
public DataTable GetAll(){ DataTable dt = new DataTable(); using(SqlConnection conn = new SqlConnection(_connectionstring)) { SqlCommand command = new SqlCommand("Select Id,Title,Director from Movies", conn); SqlDataAdapter dad = new SqlDataAdapter(command); // 初始化Table dad.Fill(dt); } return dt;}
以上,可以看出,SqlDataAdapter构造函数可以传入一个SqlCommand对象。在ADO.Net中SqlDataAdapter构造函数可以使用以下几种方法进行构造
● SqlDataAdapter(): 无参数,构造后,可以给SqlDataAdapter对象的SelectCommand属性分配一个SqlCommand对象。
作为补充,SqlDataAdapter还有UpdateCommand、DeleteCommand、InsertCommand属性,这些属性在后面会提到。
● SqlDataAdapter(string commandText, SqlConnection connection): 第一个参数为T-SQL语句,第二个参数为一个SqlConnection对象。
使用这个构造函数时,不需要显式声明SqlCommand对象。
● SqlDataAdapter(string commandText, string connectionString): 例1使用的方法,不需要显式声明SqlConnection与SqlCommand对象
● SqlDataAdapter(SqlCommand command): 例2使用的方法。
3. SqlDataAdapter的Fill/FillSchema方法
DataAdapter对象的Fill方法,该方法不止可以传入DataTable作为参数,也可以传入DataSet作为参数。
DataAdapter对象的FillSchema方法,可以向DataSet/DataTable参数添加现有的数据库约束。
3.1 赋值到DataSet
因为DataSet是DataTable的集合,所以可以Fill多张表到DataSet对象中。
例3: Fill多张数据表到DataSet对象
private void buttonFillData_Click(object sender, EventArgs e){ DataSet userData = new DataSet(); using (SqlConnection testConnection = new SqlConnection(connectionString)) { SqlCommand testCommand = testConnection.CreateCommand(); testCommand.CommandText = "Select FirstName, LastName from userTable; Select PermissionType from PermissionsTable"; SqlDataAdapter dataAdapter = new SqlDataAdapter(testCommand); dataAdapter.Fill(userData); } // testConnection.Dispose called automatically.}
3.2 Fill方法的重载
默认的,当调用SqlDataAdapter.Fill(DataSet)时,并没有指定Table名,所以,要想取得DataSet中的DataTable对象,需要使用Index序号。
也可以指定当Fill进DataSet时,相应表的TableName属性,当需要指定TableName属性时,调用以下Fill方法:
public int Fill(DataSet dataSet, string srcTable);
以下的例子是它们之间的区别:
例4: 调用Fill方法填充到DataSet时,指定TableName属性
protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { string _connectionstring = WebConfigurationManager.ConnectionStrings["DawnEnterpriseDBConnectionString"]. ConnectionString.ToString(); DataSet ds = new DataSet(); using (SqlConnection conn = new SqlConnection(_connectionstring)) { SqlCommand command = new SqlCommand("Select Id,Title,Director from Movies", conn); SqlDataAdapter dad = new SqlDataAdapter(command); dad.Fill(ds, "Movies"); // 调用Fill方法时,使用TableName dad.SelectCommand = new SqlCommand("select Id,name from MovieCategories", conn); dad.Fill(ds); // 为使用TableName GridView1.DataSource = ds.Tables["Movies"]; // 使用TableName进行指定 GridView1.DataBind(); GridView2.DataSource = ds.Tables[]; // 使用inde进行指定 GridView2.DataBind(); } } }
Fill被重载的方法有很多,具体可以查看:http://msdn.microsoft.com/zh-cn/library/system.data.sqlclient.sqldataadapter.fill.aspx
3.3 DataAdapter的FillSchema方法
SqlDataAdapter 类提供 Fill 和 FillSchema 两种方法,这对于加载这些数据很关键。这两种方法均可将信息加载到 DataSet 中。Fill 加载数据本身,而 FillSchema 加载有关特定表的所有可用的元数据(如列名、主键和约束)。处理数据加载的正确方式是先运行 FillSchema,后运行 Fill。例如:
daAuthors.FillSchema(dsPubs,SchemaType.Source, "Authors");
daAuthors.Fill(dsPubs,"Authors");
具体的参照以下几篇文章:
http://msdn.microsoft.com/zh-cn/library/49z48hxc.aspx
http://support.microsoft.com/kb/314145/zh-cn
例5:调用FillSchema方法:
//一般先用FillSchema来填入详细的元数据信息,再用Fill来填充数据,例如:
sqlDataAdapter1.FillSchema(dataSet1,SchemaType.Source,"authors");sqlDataAdapter1.Fill(dataSet1,"authors");DataColumn[] colArr;colArr = dataSet1.Tables["authors"].PrimaryKey;MessageBox.Show("Column Count: " + colArr.Length.ToString());for(int i = ; i < colArr.Length; i++){ MessageBox.Show(colArr[i].ColumnName + " " + colArr[i].DataType.ToString());}
在上例中,如果不调用FillSchema, 缺省情况下不会填如PrimaryKey信息。
另外,DataAdapter还有一个MissingSchemaAction属性,该属性可以接受以下Enum值:
● Add---在添加新行时向DataTable中添加必须的附加列(默认值)
● AddWithKey---在添加新行时向DataTAble中添加所有必须的列。
● Error---在添加新行时,如果此行不匹配现在的DataTable,就引发一个错误。
● Ignore---在添加新行时,如果此行中包含DataTable中没有的列,那么忽略多余的列。
ds.MissingSchemaAction = MissingSchemaAction.AddWithkey
asp.net学习之ado.net(无连接模式中的DataAdapter)的更多相关文章
- asp.net学习之ado.net(连接模式访问)
原文:asp.net学习之ado.net(连接模式访问) ado.net框架支持两种模式的数据访问: 连接模式(Connected)和非连接模式(disconnected).这一节介绍如何使用连 ...
- <原>ASP.NET 学习笔记之HTML helper中参数何时会是路由参数,何时又会是query string?
HTML helper中参数何时会是路由参数,何时又会是query string? @Html.ActionLink("Edit", "Edit", new ...
- 第八周学习笔记-ADO.Net中DataTable的应用
ADO.Net中DataTable的应用 一.知识点描述 1.概述:DataTable是一个临时保存数据的网格虚拟表(表示内存中数据的一个表),是ADO.Net库中的核心对象. 2.DataTabl ...
- asp.net学习之SqlDataSource
原文:asp.net学习之SqlDataSource 通过 SqlDataSource 控件,可以使用 Web 服务器控件访问位于关系数据库中的数据.其中可以包括 Microsoft SQL Serv ...
- asp.net学习之Repeater控件
asp.net学习之Repeater控件 文章摘自:http://www.cnblogs.com/shipfi/archive/2009/10/19/1585703.html Repeater控件和D ...
- asp.net学习资源汇总
名称:快速入门地址:http://chs.gotdotnet.com/quickstart/描述:本站点是微软.NET技术的快速入门网站,我们不必再安装.NET Framework中的快速入门示例程序 ...
- asp.net学习之DataList控件
asp.net学习之DataList控件 DataList控件与Repeater控件一样由模板驱动,与Repeater控件不同的是: DataList控件默认输出是一个HTML表格.DataLis ...
- asp.net学习之 数据绑定控件--List数据绑定控件
原文:asp.net学习之 数据绑定控件--List数据绑定控件 List控件(如 CheckBoxList.DropDownList.ListBox 和 RadioButtonList 类)继承自L ...
- asp.net学习之数据绑定控件、数据源控件概述
原文:asp.net学习之数据绑定控件.数据源控件概述 1.asp.net数据绑定控件分为三大类,每个类分别进行详细: ● 列表式数据绑定控件: 列表式数据绑定控件常用来在一个表格内的一个字 ...
随机推荐
- 解决android3.0版本号以上应用接收不到开机广播问题
如今是2014-07-16 下午15:27. 好久没写过东西,突然间灵感喷发想写点东西(事实上是刚刚弄好了一个棘手的问题,自豪中..呵呵呵呵 我牛掰).废话不多说,进入正题. 不知道你们又没有碰到这问 ...
- 2015华为德州扑克入境摘要——软体project
直到6一个月2号下午12时00,华为长达一个月的德州扑克锦标赛落下帷幕也被认为是. 我们的团队一直共同拥有3民,间.一个同学(吴)负责算法设计,一个同学(宋)负责分析消息,而我负责的实现框架设计和详细 ...
- ASF(传感器)
版权声明:曾经的Blog文章合并.原创作品,谢绝转载.否则将追究法律责任. SensorManager类:用于创建sensor service的实例.该类提供了非常多 用于訪问和枚举传感器,注冊和注销 ...
- [Servlet3.0新功能]注释替代配置文件
作者信息 作者名称:金云龙 个人网站:http://www.longestory.com 个人公众帐号:搜索"longestory"或"龙哥有话说" 须要注意的 ...
- OpenCV+MFC显示图像
1.首先下载openCV. 2.安装OpenCV.现在的版本号2.4.9,你并不需要配置环境变量. 3.设置包括文件夹,设定project库文件夹. 4.配置链接库.注意,链接库包含了文件名中包含一个 ...
- 【C语言探索之旅】 第二课:工欲善其事,必先利其器
内容简介 1.课程大纲 2.第一部分第二课:工欲善其事,必先利其器 3.第一部分第三课预告:你的第一个程序 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C ...
- iOS如何添加照片模拟器(附带诉讼)
刚開始做图片选择时,使用了最笨的办法给iphone模拟器添加照片. 方法一:首先打开safari.然后找到图片.点击图片,保存到本地(iphone): 方法二:拖动本地计算机的随意一张照片到iphon ...
- POJ2112Optimal Milking(二分法+floyd最短+网络流量)
职务地址:http://poj.org/problem?id=2112 近期忙着预习课本备考,没怎么刷题.(我是真的有在好好看书..)不敲题还是手痒痒.立即就邀请赛了,还是每晚睡觉前都拿来刷题吧.白天 ...
- js 模块化的规范
The Module Pattern,模块模式,也译为模组模式,是一种通用的对代码进行模块化组织与定义的方式.这里所说的模块(Modules),是指实现某特定功能的一组方法和代码.许多现 ...
- Ehcache BigMemory: 摆脱GC困扰(转)
问题 使用java开源项目经常需要调优jvm,以优化gc.对于gc,如果对象都是短时对象,那么jvm相对容易优化,假如碰上像solr使用自带java cache的项目,那么gc严重受限于cache,因 ...