ADO.NET中的DataReader详解
2018-06-18 02:59:43来源:未知 阅读 ()
使用特性
原理图
PS:Read()使指针下移,同时销毁上一条。所以SqlDataReader是只进的。
GetValue()是找当前行中的列
SqlDataReader()特性。
1)只进的 上面原理图描述了。
2)只读的 SqlDataReader只能获取,不能修改。
3)使用SqlDataReader必须保证,Connection的状态是打开的。
因为结果集存储在数据库服务器中,不打开连接是找不到。
读数据的方式
1.reader.GetValue(0)
没有列名的重载。
2.reader[1]
索引器就是用GetValue(0)实现的。
3.reader["列名"]
内部通过GetOrdinal()实现的//先获取索引 int index = reader.GetOrdinal(columnName); //再通过索引找到对应的列。 reader.GetValue(index); /***注意***:reader["列名"]的执行效率非常差,不建议使用。 因为如果这样的语句在循环中,循环多少次,就会执行 多少次没用的 int index = reader.GetOrdinal(columnName); */
//把获取列名写在循环外头。 int c1 = reader.GetOrdinal("列名"); while(reader.Read()) { object obj = reader[c1]; }
获取强类型数据
reader.GetString(0); reader.GetINT32(1); reader.GetDouble(2);//数据库里的float,这里要用Double。
为什么要获取强类型呢?
因为Object对象在使用时,要进行一次拆箱,要有性能损耗的。
DataReader读取两个结果集
do{ if(reader.HasRows) { while(reader.read()) { /*读数据*/ } } } //如果有其他结果集,就继续循环! while(reader.NextResult());
动态的获取强类型
if(reader.HasRows) { while(reader.Read()) { //遍历列 for(int i =0;i<reader.FieldCount;i++) { //获取数据类型 string dbType =reader.GetDataTypeName(i); switch(dbType) { case "varchar": case "nvarchar" case "char": case "nchar": reader.GetString(i) ;//简写 break; case "int": ...... } } } }
IsDBNull
当结果集中的列为null,并且需要用强类型获取时,需要用IsDBNull判断一下。
string obj = reader.IsDBNull(0)? "" : reader.GetString(0);
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:C#委托
- C语言中的宏定义 2020-04-04
- c++中的多态机制 2020-04-04
- Window中的shellcode编写框架(入门篇) 2020-03-31
- C++ 类中的函数重载 2020-03-24
- c++中的异常处理 2020-03-21
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash