如何在ADO中使用数据读取器(DataReader)读取数据
DbDataReader类型(实现IDataReader接口)是从数据源获取信息最简单也最快速的方法。
数据读取器是只读向前的效据流.井且一次返回一条记录。因此.只有当你向数据源提交 Select 查询语句的时候,数据读取器才有用。当你需要快速获取大批数据并且不需要在内存中存储它们的时候,数据读取器就非常有用了。比如.你想从表中取出2000条记录保存到文本文件.先用Dataset保存这些数据到内存中就非常不值得了(因为 Dataset同时在内存中保存整个结果)。
一个更好的方式是用数据读取器快速遍历每条记录。需要知道的是.数据读取器对象(不像数据适配器对象.后面会讨论它)会保持打开的连接.除非显式地关闭会话。
通过执行命令对象的 ExecuteReader()方法来获得数据读取器对象。数据读取器(DataReader)表示从数据库中读取的当前记录。它包含一个索引器方法 (如 C#中的[]语法),可以通过名称或从 0 开始的整数来访问当前记录中的列。
使用数据读取时获取单个结果集
using (SqlConnection cn = new SqlConnection())
{
cn.ConnectionString = @"Data Source=CLPDXX0076\SQLEXPRESS;" + "Integrated Security=SSPI;Initial Catalog=CarSYS";
cn.Open();
string sql = "select * from Person";
SqlCommand cmd = new SqlCommand(sql, cn);
using (SqlDataReader sr = cmd.ExecuteReader())
{
while (sr.Read())
{
//Console.WriteLine("ID:{0},Name:{1},Age:{2}", sr["ID"],sr["Name"],sr["Age"]); for (int i = ; i < sr.FieldCount; i++)
{
Console.WriteLine("{0}={1}", sr.GetName(i), sr.GetValue(i).ToString());
}
}
}
}
使用数据读取时获取多个结果集
using (SqlConnection cn = new SqlConnection())
{
cn.ConnectionString = @"Data Source=服务器名;" + "Integrated Security=SSPI;Initial Catalog=数据库名";
cn.Open();
string sql = "select * from Person;select * from Product";
SqlCommand cmd = new SqlCommand(sql, cn);
using (SqlDataReader sr = cmd.ExecuteReader())
{
do
{
while (sr.Read())
{
for (int i = ; i < sr.FieldCount; i++)
{
Console.WriteLine("{0}={1}", sr.GetName(i), sr.GetValue(i).ToString());
}
Console.WriteLine();
} } while (sr.NextResult());
}
}
如何在ADO中使用数据读取器(DataReader)读取数据的更多相关文章
- ADO.Net读取器获取数据库数据
string str = Configuration.ConfigurationManager.AppSettings[str].ToString(); string sql = "sele ...
- 如何在Elasticsearch中安装中文分词器(IK+pinyin)
如果直接使用Elasticsearch的朋友在处理中文内容的搜索时,肯定会遇到很尴尬的问题--中文词语被分成了一个一个的汉字,当用Kibana作图的时候,按照term来分组,结果一个汉字被分成了一组. ...
- 如何在Elasticsearch中安装中文分词器(IK)和拼音分词器?
声明:我使用的Elasticsearch的版本是5.4.0,安装分词器前请先安装maven 一:安装maven https://github.com/apache/maven 说明: 安装maven需 ...
- 前端技术之:如何在Vue中使用clipboard.js复制服务端数据
第一步 创建点击对象页面元素,并绑定业务数据. <el-button type="text" size="mini" class="copy-b ...
- 如何在elasticsearch中查看Logstash打到elasticsearch的数据
# cat syslog02.conf #filename:syslog02.conf #注意这个是要用#号注释掉 input{ file{ path => ["/var/log/*. ...
- 简述在ADO中使用接口的抽象数据提供程序以及ADO.NET数据提供程序工厂模型
如何在ADO中使用接口的抽象数据提供程序 在cofig中 appSettings下,配置数据连接类型 <appSettings> <!--这个键值映射到枚举值中的某个值--> ...
- C#与数据库访问技术总结(十一)之数据阅读器(DataReader)1
数据阅读器 当执行返回结果集的命令时,需要一个方法从结果集中提取数据. 处理结果集的方法有两个: 第一,使用数据阅读器(DataReader): 第二,同时使用数据适配器(Data Adapter)和 ...
- (第二章第四部分)TensorFlow框架之TFRecords数据的存储与读取
系列博客链接: (第二章第一部分)TensorFlow框架之文件读取流程:https://www.cnblogs.com/kongweisi/p/11050302.html (第二章第二部分)Tens ...
- 028 Partitioner:数据分区器
Partitioner:数据分区器,决定数据到下一个RDD的时候在那一个分区 HashPartitioner:根据key的hashCode值来实现 RangePartitioner: 根据key所属范 ...
随机推荐
- Keras框架简介
Keras是基于Theano的一个深度学习框架,它的设计参考了Torch,用Python语言编写,是一个高度模块化的神经网络库,支持GPU和CPU.使用文档在这:http://keras.io/,中文 ...
- Netty实现高性能IOT服务器(Groza)之手撕MQTT协议篇上
前言 诞生及优势 MQTT由Andy Stanford-Clark(IBM)和Arlen Nipper(Eurotech,现为Cirrus Link)于1999年开发,用于监测穿越沙漠的石油管道.目标 ...
- Ethercat 学习总结一:协议总结
原文地址:https://blog.csdn.net/qq923433160/article/details/83781812 EtherCAT 总线的国家标准相关资料,比较详细介绍了协议: http ...
- SSL,TLS
今天突然收到邮件说SSL不能用了,基于SSL的HTTPS协议不通了,怎么办? java/android 的网络编程简直一窍不通,平时都是用到了问百度.只能恶补有关网络的知识了. 传输协议: 传输协议中 ...
- DES加解密
package encrypt; import java.security.Key; import java.security.SecureRandom; import java.util.Base6 ...
- Springcloud Gateway 路由管理
Spring Cloud Gateway 是 Spring Cloud 的一个全新项目,该项目是基于 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等技术开 ...
- bash语法
国际惯例打印hello world echo "hello world" 该程序运行结果: hello world 1.变量: a=;b="hello wor ...
- 分享一个.NET平台开源免费跨平台的大数据分析框架.NET for Apache Spark
今天早上六点半左右微信群里就看到张队发的关于.NET Spark大数据的链接https://devblogs.microsoft.com/dotnet/introducing-net-for-apac ...
- Redis客户端——Jedis的使用
本文介绍基于Java语言的Redis客户端——Jedis的使用,包括Jedis简介.获取Jedis.Jedis直连.Jedis连接池以及二者的对比的选择. Jedis简介 Jedis 是 Redis ...
- jQuery拼图小游戏
jQuery拼图小游戏 最后样式 核心代码部分 <script type="text/javascript" > $(function () { $("td& ...