亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

DataAdapter執行批量更新的實例代碼

2024-07-10 13:15:53
字體:
來源:轉載
供稿:網友

在以前版本的 ADO.NET 中,使用 DataSet 中的更改來更新數據庫時,DataAdapter 的 Update 方法每次更新數據庫的一行。因為該方法循環訪問指定 DataTable 中的行,所以,會檢查每個 DataRow,確定是否已修改。如果該行已修改,將根據該行的 RowState 屬性值調用相應的 UpdateCommand、InsertCommand 或 DeleteCommand。每一次行更新都涉及網絡與數據庫之間的雙向數據傳輸。
    在 ADO.NET 2.0 中,DataAdapter 公開了 UpdateBatchSize 屬性。將 UpdateBatchSize 設置為正整數值將使對數據庫的更新以指定大小的批次進行發送。例如,如果將 UpdateBatchSize 設置為 10,會將 10 個獨立的語句組合在一起并作為一批提交。將 UpdateBatchSize 設置為 0 將導致 DataAdapter 使用服務器可以處理的最大批次的大小。如果將其設置為 1,則禁用批量更新,因為此時每次發送一行。
    執行非常大的批次可能會降低性能。因此,在實現應用程序之前,應測試最佳的批次大小設置。
    使用 UpdateBatchSize 屬性
    啟用了批量更新后,DataAdapter 的 UpdateCommand、InsertCommand 和 DeleteCommand 的 UpdatedRowSource 屬性值應設置為 None 或 OutputParameters。在執行批量更新時,命令的 FirstReturnedRecord 或 Both 的 UpdatedRowSource 屬性值無效。
    下面的過程演示如何使用 UpdateBatchSize 屬性。該過程采用兩個參數,一個 DataSet 對象,其中包含代表 PRoduction.ProductCategory 表中的 ProductCategoryID 和 Name 字段的列,一個代表批次大小的整數(批次中的行數)。該代碼創建一個新的 SqlDataAdapter 對象,設置其 UpdateCommand、InsertCommand 和 DeleteCommand 屬性。該代碼假定 DataSet 對象已修改了行。它設置 UpdateBatchSize 屬性并執行更新。

復制代碼 代碼如下:


    protected void btnUpdateAddress_Click(object sender, EventArgs e)
    {
    SqlDataAdapter EmpAdapter = new SqlDataAdapter();
    DataTable EmpDT = new DataTable();
    SqlConnection DBConSelect = new SqlConnection();
    SqlConnection DBConUpdate = new SqlConnection();
    SqlCommand SelectCommand = new SqlCommand();
    SqlCommand UpdateCommand = new SqlCommand();
    // Using different connection objects for select and updates from the
    // Northwind database.
    DBConSelect.ConnectionString =
    ConfigurationManager.ConnectionStrings["DSN_NorthWind"].ConnectionString;
    DBConUpdate.ConnectionString =
    ConfigurationManager.ConnectionStrings["DSN_NorthWind"].ConnectionString;
    // Reading all records from the Employees table
    SelectCommand.CommandText = "SELECT top 500 * FROM EMPLOYEES";
    SelectCommand.CommandType = CommandType.Text;
    SelectCommand.Connection = DBConSelect;

 UpdateCommand.CommandText = " UPDATE EMPLOYEES SET Address=@Address, " +
    "City=@City, Region=@Region, Country=@Country";
    UpdateCommand.CommandType = CommandType.Text;
    UpdateCommand.Connection = DBConUpdate;
    SqlParameter AddressParam;
    AddressParam = new SqlParameter("@Address",
    SqlDbType.VarChar, 15, "Address");
    SqlParameter CityParam;
    CityParam = new SqlParameter("@City", SqlDbType.VarChar, 15, "City");
    SqlParameter RegionParam;
    RegionParam = new SqlParameter("@Region", SqlDbType.VarChar, 15, "Region");
    SqlParameter CountryParam;
    CountryParam = new SqlParameter("@Country",
    SqlDbType.VarChar, 15, "Country");
    UpdateCommand.Parameters.Add(AddressParam);
    UpdateCommand.Parameters.Add(CityParam);
    UpdateCommand.Parameters.Add(RegionParam);
    UpdateCommand.Parameters.Add(CountryParam);
    // Setting up Data Adapter with the Select and Update Commands
    // The Select command will be used to retrieve all employee
    // information from the Northwind database and the Update command
    // will be used to save changes back to the database
    EmpAdapter.SelectCommand = SelectCommand;
    EmpAdapter.UpdateCommand = UpdateCommand;
    EmpAdapter.Fill(EmpDT);
    DBConSelect.Close();
    // Looping through all employee records and assigning them the new
    // address
    foreach (DataRow DR in EmpDT.Rows)
    {
    DR["Address"] = "4445 W 77th Street, Suite 140";
    DR["City"] = "Edina";
    DR["Region"] = "Minnesota";
    DR["Country"] = "USA";
    }
    // Adding an event handler to listen to the RowUpdated event.
    // This event will will fire after each batch is executed
    EmpAdapter.RowUpdated +=  new SqlRowUpdatedEventHandler(OnRowUpdated);
    lblCounter.Text = "";
    EmpAdapter.UpdateBatchSize = 100;
    // It is important to set this property for batch processing of
    // updated records since batch updates are incapable of
    // updating the source with changes from the database
    UpdateCommand.UpdatedRowSource = UpdateRowSource.None;
    try
    {
    DBConUpdate.Open();
    EmpAdapter.Update(EmpDT);
    }
    catch (Exception ex)
    {
    lblCounter.Text += ex.Message + "<Br>";
    }
    finally
    {
    if (DBConUpdate.State == ConnectionState.Open)
    {
    DBConUpdate.Close();
    }
    }
    }
    private void OnRowUpdated(object sender, SqlRowUpdatedEventArgs args)
    {
    lblCounter.Text += "Batch is processed till row number = " +
    args.RowCount.ToString() + "<br>";
    }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
丁香五六月婷婷久久激情| 日日狠狠久久偷偷四色综合免费| 91久久国产精品| 久久久久久免费精品| 国产精品都在这里| 欧美小视频在线观看| 午夜精品久久久久久99热软件| 色狠狠av一区二区三区香蕉蜜桃| 久久精品国产亚洲精品| 国产精品igao视频| 韩剧1988免费观看全集| 亚洲高清一二三区| 国产精品综合不卡av| 777国产偷窥盗摄精品视频| 精品久久久av| 91久久在线播放| 日韩av成人在线| 欧美日韩在线视频观看| 91精品久久久久久久久久久| 亚洲偷欧美偷国内偷| 欧美一区深夜视频| 一区二区亚洲欧洲国产日韩| 日韩欧美在线视频日韩欧美在线视频| 色偷偷综合社区| 亚洲第一网站男人都懂| 91精品国产综合久久香蕉最新版| 在线视频国产日韩| 国产精品成av人在线视午夜片| 国产精品视频网| 欧美xxxx18性欧美| 日韩欧美国产中文字幕| 久久久精品日本| 91亚洲国产成人精品性色| 中文字幕日本精品| 7m精品福利视频导航| 国产精品网红福利| 日韩精品小视频| 综合136福利视频在线| 日韩高清免费观看| 久久久免费观看| 国产日韩欧美视频| 欧美成人一区在线| 九九热最新视频//这里只有精品| 日本午夜在线亚洲.国产| 日韩在线视频播放| 日韩黄色高清视频| 欧美精品www在线观看| 性金发美女69hd大尺寸| 亚洲欧美在线一区| 亚洲欧美国产精品久久久久久久| 国产成人免费91av在线| 精品国产一区二区三区四区在线观看| 国产欧美日韩中文字幕在线| 91精品久久久久久久久中文字幕| 精品爽片免费看久久| 亚洲性线免费观看视频成熟| 日韩av在线影视| 久久久久久久一区二区| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲精品美女在线| 性亚洲最疯狂xxxx高清| 国产精品高清免费在线观看| 欧美成人自拍视频| 色综合久久中文字幕综合网小说| 欧美日韩国产色视频| 另类少妇人与禽zozz0性伦| 亚洲韩国日本中文字幕| 亚洲成人黄色网址| 亚洲精品不卡在线| 亚洲女人天堂网| 欧美久久精品一级黑人c片| 久久免费国产视频| yw.139尤物在线精品视频| 久久精品国产电影| 午夜精品一区二区三区在线| 96精品久久久久中文字幕| 国产精品27p| 国产精品丝袜视频| 成人精品久久久| 日本道色综合久久影院| 激情成人中文字幕| 亚洲国产美女久久久久| 亚洲自拍小视频免费观看| 懂色aⅴ精品一区二区三区蜜月| 久久亚洲综合国产精品99麻豆精品福利| 亚洲国产精品久久| 中文字幕精品一区二区精品| 亚洲第一av网| 亚洲aⅴ日韩av电影在线观看| 日韩美女在线看| 精品一区二区三区三区| 色天天综合狠狠色| 久久手机精品视频| 亚洲成av人片在线观看香蕉| 日韩美女免费线视频| 国产亚洲视频在线观看| 成人福利网站在线观看11| 亚洲毛片在线观看| 欧美成年人视频| 国产欧美精品一区二区三区-老狼| 亚洲国产精品国自产拍av秋霞| 欧美在线视频观看免费网站| 欧美成人国产va精品日本一级| 成人疯狂猛交xxx| 欧美另类xxx| 国产精品v片在线观看不卡| 欧美激情精品久久久久久久变态| 欧美性视频精品| 国产精品一区二区三区久久久| 亚洲欧美国产一区二区三区| 国产精品狼人色视频一区| 韩国三级日本三级少妇99| 国产精品91久久久久久| 久久久国产精品免费| 亚洲深夜福利网站| 国产日韩av在线播放| 久久精品国产亚洲一区二区| 国产91对白在线播放| www.久久久久久.com| 亚洲精品国产精品国自产观看浪潮| 久久国产精彩视频| 日韩电影在线观看永久视频免费网站| 欧美一二三视频| 欧美一区深夜视频| 色综合91久久精品中文字幕| 5566成人精品视频免费| 欧美成人第一页| 26uuu另类亚洲欧美日本一| 久久视频国产精品免费视频在线| 日本久久久a级免费| 国内揄拍国内精品少妇国语| 黄色一区二区在线观看| 亚洲人成在线播放| 亚洲精品美女久久久| 日韩美女在线看| 亚洲精品一区二区三区婷婷月| 亚洲欧美日韩一区二区三区在线| 欧美日韩免费一区| 国产精品久久久久久久久免费| 亚洲jizzjizz日本少妇| 久久伊人精品一区二区三区| 中文欧美日本在线资源| 欧美在线视频播放| 亚洲直播在线一区| 亚洲aa中文字幕| 国产成人精品久久亚洲高清不卡| 国产精品69精品一区二区三区| 亚洲精品女av网站| 日韩精品视频在线观看网址| 91久久国产精品| 亚洲色图偷窥自拍| 欧美性猛交xxxx富婆弯腰| 国产精品免费看久久久香蕉| 91九色在线视频| 国产噜噜噜噜久久久久久久久| 亚洲xxxx做受欧美| 91系列在线播放| 欧美日韩亚洲一区二区三区| 国内精品美女av在线播放| 欧美精品做受xxx性少妇| 最近日韩中文字幕中文| 亚洲sss综合天堂久久| 日韩欧美国产激情| 久久精品色欧美aⅴ一区二区|