<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Hopes

    Start Here..

     

    DataReader和DataSet的區別

    DataReader和DataSet的區別

    分類: 小知識點
    2010-06-24 14:44 111人閱讀 評論(0) 收藏 舉報

    1. 獲取數據的方式
    DataReader為在線操作數據, DataReader會一直占用SqlConnection連接,在其獲得數據過程中其它操作不可以再使用SqlConnection連接對象。
    DataSet為離線操作數據,DataSet會將數據一次性讀入內存,然后斷開連接,這時其它操作就可以使用SqlConnection連接對象。
    由于DataReader一次只讀取一行數據,所以占用內存較小。但DataReader為只進且只讀的,也就是只能單方向向前讀取,如果你想回頭去讀取上一條數據是不允許的,并且不允許其修改數據。
    由于DataSet一次性讀取所有數據,所以比較消耗資源,但也提高了靈活性,在斷開數據庫連接情況下你可以對數據進行任何增刪改查,按照任意的順序讀取數據,并可以將其寫回到數據庫。
    有一點需要注意,DataReader一次讀取一行并不意味了著這時在數據庫中的數據被修改,可以讀到新的數據,這是數據庫層面的保護.
    2.獲取數據的機制
    DataReader是通過IDbCommand.ExecuteReader來讀取數據。
    DataSet則是通過DbDataAdapter.Fill來填充數據
    所以DataReader在獲取數據時不能關閉連接。而DataSet則可以,因為DbDataAdapter已經將數據讀取到應用程序服務器中,所以在使用DataReader時一定要注意,及時關閉連接。
    3.其它區別
    DataReader讀取速度快于DataSet
    DataReader是數據提供者類,DataSet是一般性類,借助于DbDataAdapter來填充數據。
    因為DataSet是離線操作數據,所以在事務中使用鎖時要注意,因為DataSet填充數據后會斷開連接,也就會釋放鎖。

    posted on 2012-09-17 15:43 ** 閱讀(181) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     

    導航

    統計

    公告

    你好!

    常用鏈接

    留言簿(2)

    隨筆檔案

    文章分類

    文章檔案

    新聞檔案

    相冊

    收藏夾

    C#學習

    友情鏈接

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲日韩精品无码一区二区三区| 日韩吃奶摸下AA片免费观看 | 亚洲日韩精品无码专区加勒比| 亚洲中文字幕第一页在线| 免费黄色app网站| 99国产精品永久免费视频| 免费国产成人午夜在线观看| 黄色一级视频免费| 黄网站色视频免费看无下截 | 99re热免费精品视频观看 | 日韩大片免费观看视频播放| 久久精品国产亚洲av麻豆蜜芽| 亚洲AV人人澡人人爽人人夜夜| 亚洲乳大丰满中文字幕| 国产亚洲?V无码?V男人的天堂| 又黄又大又爽免费视频| 全黄a免费一级毛片人人爱| 国产小视频在线观看免费| 一本色道久久88综合亚洲精品高清| 国产精品无码一二区免费| 四虎永久成人免费影院域名| 无码专区一va亚洲v专区在线| 亚洲综合精品香蕉久久网| 亚洲国产精品久久久久婷婷老年| 久久亚洲精品无码aⅴ大香| 亚洲av无码一区二区三区在线播放| 狼人大香伊蕉国产WWW亚洲| 亚洲成a人无码亚洲成av无码 | 最近中文字幕无免费| 永久久久免费浮力影院| 亚洲国产精品自在在线观看| 美女被爆羞羞网站在免费观看 | 亚洲伊人久久大香线蕉苏妲己| 西西人体大胆免费视频| 国产久爱免费精品视频| 免费大片黄在线观看yw| 亚洲AV午夜福利精品一区二区 | 成在人线AV无码免费| 亚洲AⅤ优女AV综合久久久| 亚洲av无码成h人动漫无遮挡 | 日韩免费a级毛片无码a∨|