DataReader深入解析:持续更新


//香水坏坏 AT 06-07-25

//郁闷的事情总是接连不断,无形的压力来自内心的恐惧

大家在用.net进行数据操作的时候,接触DataReader不少。


System.Data.OleDb.OleDbDataReader;
System.Data.Odbc.OdbcDataReader;
System.Data.SqlClient.SqlDataReader;

inherit from
System.MarshalByRefObject;//允许在支持远程处理的应用程序中跨应用程序域边界访问对象。
System.Collections.IEnumerable;
System.Data.IDataReader;
inherit from
System.Data.IDataRecord;
System.IDisposable;
//IDataReader 定义了 获取一行记录的值以及字段名的通用方法以及属性接口 如:object this[string name] { get; }; object this[int i] { get; }

下面详细讲解一下 this[string name] 以及this[int i]属性(相信大家调用的比较频繁)
这二个属性我想大家在使用NameValueCollection见的比较多,其实不然,他们完全是二个不个不同的概念
其实这里this[string name]是this[int i]的一个方便的操作
首先在this[string name]通过GetOrdinal方法获取字段名的索引再调用GetValue方法取值
由此可见通过调用this[int i]比通过调用this[string name]取值效率要高那么点点 *-*呵呵

GetOrdinal方法其实是通过GetName方法遍列所有字段名并进行对比,如果没返回字段对应的索引号将抛出一个异常

//今天先就到这 有时间再补充(昨天网络不通,今天补发上来



相关阅读:
定义列表
Mysql5.0 存储过程
javascript,php获取函数参数对象的代码
"PageMethods未定义"或"对象不支持此属性或方法"解决方法分享
什么是Semantics?
Ubuntu Apache 服务之 PHP 配置
CSS 选择器浅谈
文本框根据输入内容自适应高度的代码
Excel导入Sqlserver数据库脚本
极致之美——百行代码实现全新智能语言
php jquery 实现新闻标签分类与无刷新分页
在.Net中用数据工厂进行多数据库操作
Windows Embedded性能
CSS hack实现 CSS完美兼容IE6/IE7/FF的通用方法
快速导航

Copyright © 2016 phpStudy | 皖ICP备18014864号-4