全国统一热线:
028-86758058
18980748058
购买流程
付款方式
常见问题
在线提问
续租服务
购物车(
0
件)
用户名:
密 码:
记住
首 页
HOME
域名注册
DOMAIN
虚拟主机
WEB HOST
成品网站超市
AUTO Site
VPS主机
VPS SERVER
云 主 机
CLOUD HOST
租用托管
SERVER
海外主机
HK HOST
代理专区
AGENT
客服中心
SERVICE
站长教程
SERVICE
欢迎光临西部数据云计算中心,我们将竭诚为您提供最优质的服务!
中文域名
域名转入
域名转出
DNS管理
动态域名
获取域名证书
域名停放
域名过户
集群主机
双线主机
基本主机
港台主机
论坛主机
Linux主机
Vip合租主机
超G型主机
ASP.net主机
Java主机
智能建站主机
网店主机
美国主机
数据库
成品网站超市
智能建站主机
集群VPS主机
国内VPS主机
香港VPS主机
美国VPS主机
云主机介绍
云主机购买
服务器租用
主机托管
常见问题
香港主机
港台主机
美国主机
国内免备案
步骤流程
代理级别
代理合同
代理模式
代理优势
在线申请
产品列表
常见问题
代理商分布图
常见问题
有问必答
跟踪提问
购买流程
产品价格
付款方式
常用软件
网站备案
续租服务
汇款确认
相关文档
联系我们
域名资讯
主机资讯
行业动态
网页制作
php教程
mysql教程
域名资讯
云计算资讯
网络编程
您当前的位置:
首页
>
网络编程
>
Net教程
详细说明asp.net中datareader 和 dataset 的区别
时间:2015-01-29 来源:互联网 作者:佚名
1. 获取数据的方式
DataReader为在线操作数据, DataReader会一直占用SqlConnection连接,在其获得数据过程中其它操作不可以再使用SqlConnection连接对象。
复制代码
代码如下:
while(datareader.read())
{
..............
}
dataview.datasource=datareader;
dataview.databind();
DataSet为离线操作数据,DataSet会将数据一次性读入内存,然后断开连接,这时其它操作就可以使用SqlConnection连接对象。
后台代码
复制代码
代码如下:
public string test = "";
protected void Page_Load(object sender, EventArgs e)
{
DataSet ds=new DataSet();//这里是你的数据,我就不写了
test = "<table>";
for (int i = 0; i < ds.Tables[0].Rows; i++)
{
test+="<tr><td>"+ds.Tables[0].Rows[i]["你要的字段"].ToString()+"</td></tr>"
}
test+="</table>";
}
页面代码
复制代码
代码如下:
<form id="form1" runat="server">
<%=test %>
</form>
由于DataReader一次只读取一行数据,所以占用内存较小。但DataReader为只进且只读的,也就是只能单方向向前读取,如果你想回头去读取上一条数据是不允许的,并且不允许其修改数据。
由于DataSet一次性读取所有数据,所以比较消耗资源,但也提高了灵活性,在断开
数据库
连接情况下你可以对数据进行任何增删改查,按照任意的顺序读取数据,并可以将其写回到数据库。
有一点需要注意,DataReader一次读取一行并不意味了着这时在数据库中的数据被修改,可以读到新的数据,这是数据库层面的保护.
2.获取数据的机制
DataReader是通过IDbCommand.ExecuteReader来读取数据。
DataSet则是通过DbDataAdapter.Fill来填充数据
所以DataReader在获取数据时不能关闭连接。而DataSet则可以,因为DbDataAdapter已经将数据读取到应用程序
服务器
中,所以在使用DataReader时一定要注意,及时关闭连接。
3.其它区别
DataReader读取速度快于DataSet
DataReader是数据提供者类,DataSet是一般性类,借助于DbDataAdapter来填充数据。
因为DataSet是离线操作数据,所以在事务中使用锁时要注意,因为DataSet填充数据后会断开连接,也就会释放锁。
4.使用DataReader可以提高执行效率,有两种方式可以提高代码的性能:一种是基于序号的查找,一个是使用适当的Get方法来查找。因为查询出来的结果一般都不会改变,除非再次改动查询语句,因此可以通过定位列的位置来查找记录。用这种方法有一个问题,就是可能知道一列的名称而不知道其所在的位置,这个问题的解决方案是通过调用DataReader 对象的GetOrdinal()方法,此方法接收一个列名并返回此列名所在的列号。例:
复制代码
代码如下:
int id = reader.GetOrdinal("CategoryName");
while (reader.Read())
{
Response.Write(reader.GetInt32(0).ToString() + " " + reader.GetString(1).ToString() + "<br />");
reader.Close();
}
DataReader的GetInt32()和GetString()通过接收一个列号来返回一个列的值,这两种是最常用的,其中还有很多其它的类型。
(注:DataReader对象在调用Close()方法即关闭与数据库的连接,如果在没有关闭之前又重新打开第二个连接,则会产生一条异常信息)
来顶一下
返回首页
推荐资讯
模拟QQ心情图片上传预览示例
出于安全性能的考虑,目前js端不支持获取本地图片进行预览,
HTML服务器控件和WEB服务器控件的区
学习asp.net的时候,视频中总是做例子,这当然是一件好事,可是
相关文章
DataSet.Tables[].Rows[][]的用法详细解析
ASP.NET 防止按钮多次提交核心实现代码
Asp.net的GridView控件实现单元格可编辑方便用户使用
asp.net EXECUTENONQUERY()返回值介绍
asp.net 按指定模板导出word,pdf实例代码
ASP.NET 页面传值常用方法总结
如何在asp.net中使用FreeTextBox控件
asp.net 生成随机密码的具体代码
asp.net直接Response输出WML页面示例代码
ASP.NET将Session保存到数据库中的方法
栏目更新
栏目热门
返回首页
关于我们
联系我们
付款方式
价格总览
资讯中心
友情链接
媒体关注
有问必答
投诉建议
网站备案
《中华人民共和国增值电信业务经营许可证》编号:川B2-20080058号
官方网址:
xibushuju.com
西部数据
Copyright © 2002~2015
天府快车
版权所有
电话总机:
028-86758058
(50线) 传真:
028-86758058