All articles| All Pictures| All Softwares| All Video| Go home page| Write articles| Upload pictures

Reading number is top 10 articles
C#中多维数组的使用
asp.net2.0内置Response对象的属性
开发保留标准浏览器功能的AJAX应用程序_[AJAX教程]
Sql,server传送数组参数的变通办法_[SQL,Server教程]
如何解决Remoting无法传输存储过程参数的问题_[Asp.Net教程]
php采用数据库保存session_php资料_编程技术
ASP.net实现无扩展名的URL重写。简单、方便、无需ISAPI_[Asp.Net教程]
PHP实例:用PHP实现多文件上载系统程序_[PHP教程]
初学来看:动态网页制作技术PHP的变量类型_php资料_编程技术
使用.NET实现你的IP切换器_.net资料_编程技术
Reading number is top 10 pictures
Li Zongrui hunting video screenshots1
Beautiful vacuum girl3
中国处女图鉴2
The little woman's bright wire3
The real super beauty3
美女挤公交
The service WaLiangGe Chinese aircraft carrier1
Cesarean section, bloody, silently into it!2
这才是真正的人体艺术4
The world's top ten most beautiful railway station2
Download software ranking
WebService在.NET中的实战应用教学视频 → 第5集
C#编程思想
Boxer's Top ten classic battle6
Ashlynn Video5
Boxer vs Yellow5
Photoshop 8.0图象编辑软件
Boxer's Top ten classic battle3
Tram sex maniac 2 (H) rar bag5
Macromedia Dreamweaver 8
Tram sex maniac 2 (H) rar bag19
归海一刀 published in(发表于) 2014/1/30 1:16:10 Edit(编辑)
.NET开发中ADO.NET的应用总结_[Asp.Net教程]

.NET开发中ADO.NET的应用总结_[Asp.Net教程]

.NET开发中ADO.NET的应用总结_[Asp.Net教程]
一、DataTable
DataTable表示内存中数据的一个表,它完全是在内存中的一个独立存在,包含了这张表的全部信息。DataTable可以是从通过连接从数据库中读取出来形成的一个表,一旦将内容读到DataTable中,此DataTable就可以跟数据源断开而独立存在;也可以是完全由程序自己通过代码来建立的一个表。
◆ DataColumn
一个表是由行和列组成的一个两维的结构。表的结构是由DataColumn对象的集合组成,DataColumn对象集合可由DataTable.Columns属性中能获取到,通过定义每一列的数据类型来确定表的架构,类似数据库中定义表。定义完表的结构就可以根据结构来生成DataRow,用DataTable.NewRow()方法来生成此DataTable结构的新行。
一个DataTable是由DataRow的集合组成的,DataRow的集合这个可以由DataTable.Rows属性来访问。
DataTable还可以通过现有的列用Expression属性的表达式创建一些列。
1、创建计算出的列
比如:已经有了一个表结构,表中有一个DataColumn的集合,其中有一个叫UnitPrice的列,你可以新建一个DataColumn,设置好ColumnName,再设置此列的表达式,DataColumn.Expression="UnitPrice * 0.086",这个列的值就是名字为UnitPrice的列计算出来的,在创建表达式时,使用ColumnName属性来引用列。
2、第二个用途是创建聚合列
聚合列聚合通常沿着关系执行(有关关系的描述见下面DataRelation部分),如果order表有名为detail 的子表,两个表之间通过order.orderid和detail.orderid两个列建立一个关系DataRelation对象名为“order2detail”,在主表order中就可以建立一个聚合列,将计算每个order在detail表中含有的所有item的价格的和:DataColumn.Expression = “sum(child(order2detail).price)",child(order2detail)表示通过关系order2detail联系到的子表,child(order2detail).price就表示子表的price列。
◆ DataRow
DataRow对象没有直接在代码中使用的构造函数,一般是从具有一定结构的DataTable用NewRow()方法来新建一个DataRow对象。一个DataRow根据其是独立的,还是属于某个DataTable,是否修改过,是否被DataTable删除等等不同的情况有不同的状态,由DataRow.RowState属性公开,如下表:
成员名称 说明
Added该行已添加到DataRowCollection中,AcceptChanges 尚未调用。Deleted该行已通过DataRow的Delete方法被删除。
Deleted 该行已通过DataRow的Delete方法被删除。
Detached 该行已被创建,但不属于任何DataRowCollection。DataRow 在以下情况下立即处于此状态:创建之后添加到集合中之前;或从集合中移除之后。
Modified 该行已被修改,AcceptChanges 尚未调用。
Unchanged 该行自上次调用 AcceptChanges 以来尚未更改。
一个DataRow对象刚被创建之后其状态是Detached,是孤立的一个存在,所以建立了DataRow之后在DataRow中的单元填充了数据后还要通过DataTable.Rows.Add(DataRow)方法将此DataRow添加到DataTable,DataRow添加到DataTable后, 这个DataRow的状态就转变为Added。当修改了这个DataRow后,这个DataRow状态转为Modified,当用DataRow.Delete()方法删除DataRow后,DataRow状态将转为Deleted,不过此行还存在在DataTable中的,只是状态改变了,这时用DataTable.Rows.Count查看行数,跟删除前是一样的。只有在调用了DataTable.Remove(DataRow)方法后,此DataRow才被从DataTable移除,状态也回复到Detached孤立状态。
一旦调用了DataTable.AcceptChanges()方法后,所有的行将根据不同的状态做不同的处理,Added、Modified、Unchanged将保留当前值,Deleted的行将从DataTable中移除,最后所有的行的状态都置为Unchanged。当DataTable是从DataAdapter.Fill(
DataSet,DataTable)方法填充而形成的,Fill()方法将自动调用AcceptChanges()方法,将DataTable的行状态都置为Unchanged。并且,如果Fill方法中指定的那个DataTable在要填充的那个DataSet不存在时,会生成一个跟数据源表同样的结构的DataTable并填充数据。
◆ DataRelation
表示两个DataTable对象之间的父/子关系。可以类比于数据库中的表之间的关系,父表相当于关系列为主键的表,子表相当于关系列为外键的表。DataRelation 构造函数一般为:DataRelation(String, DataColumn, DataColumn) ,string为关系名,第一个DataColumn为建立关系的父表列,第二个DataColumn为建立关系的子表列,建立关系的两个列的 DataType 值必须相同。
建立好了关系,必须把这个关系加入到DataTable的ParentRelations属性或ChildRelations 属性,这两个属性包含这个表的所有的跟父表的关系和跟子表的关系。若关系中此表是父表则将此关系加入到ChildRelations集合中,否则加入到ParentRelations集合中。


添加到del.icio.us 添加到新浪ViVi 添加到百度搜藏 添加到POCO网摘 添加到天天网摘365Key 添加到和讯网摘 添加到天极网摘 添加到黑米书签 添加到QQ书签 添加到雅虎收藏 添加到奇客发现 diigo it 添加到饭否 添加到飞豆订阅 添加到抓虾收藏 添加到鲜果订阅 digg it 貼到funP 添加到有道阅读 Live Favorites 添加到Newsvine 打印本页 用Email发送本页 在Facebook上分享


Disclaimer Privacy Policy About us Site Map

If you have any requirements, please contact webmaster。(如果有什么要求,请联系站长)
Copyright ©2011-
uuhomepage.com, Inc. All rights reserved.