欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#使用DataSet Datatable更新數據庫的三種實現(xiàn)方法

 更新時間:2014年08月27日 15:29:50   投稿:shichen2014  
這篇文章主要介紹了C#使用DataSet Datatable更新數據庫的三種實現(xiàn)方法,需要的朋友可以參考下

本文以實例形式講述了使用DataSet Datatable更新數據庫的三種實現(xiàn)方法,包括CommandBuilder 方法、DataAdapter 更新數據源以及使用sql語句更新。分享給大家供大家參考之用。具體方法如下:

一、自動生成命令的條件 CommandBuilder 方法

a)動態(tài)指定 SelectCommand 屬性

b)利用 CommandBuilder 對象自動生成 DataAdapter 的 DeleteCommand、InsertCommand 和 UpdateCommand。

c)為了返回構造 INSERT、UPDATE 和 DELETE 。SQL CommandBuilder 必須執(zhí)行 SelectCommand。

即:必須額外經歷一次到數據源的行程,這可能會降低性能。這也是自動生成命令的缺點。

d)SelectCommand 還必須返回至少一個主鍵或唯一列.

當CommandBuilder和DataAdapter關聯(lián)時,就會自動生成DeleteCommand、InsertCommand 和 UpdateCommand中為空的命令。即不空的不生成。

e)必須是一個表,SELECT的不能是多個表的聯(lián)合。

動生成命令的規(guī)則:

在數據源處為表中所有 RowState 為 Added 的行插入一行(不包括標識、表達式或時間戳等列)。
為 Modified 的行更新行(列值匹配行的主鍵列值) 。
Deleted 的行刪除行(列值匹配行的主鍵列值).這就是為什么要求條件c.d

注意:

a)因為從SELECT數據到UPDATE數據,中間這段時間有可能別的用戶已經對數據進行了修改。自動生成命令這種UPDATE只對在行包含所有原始值并且尚未從數據源中刪除時更新。

b)自動命令生成邏輯為獨立表生成 INSERT、UPDATE 或 DELETE 語句,而不考慮與數據源中其他表的任何關系。因此,當調用 Update 來為參與數據庫中外鍵約束的列提交更改時,可能會失敗。若要避免這一異常,請不要使用 CommandBuilder 來更新參與外鍵約束的列,而應顯式地指定用于執(zhí)行該操作的語句。

下面是自動生成命令的例子

// Assumes that connection is a valid SqlConnection object.
SqlDataAdapter adapter = new SqlDataAdapter(
"SELECT * FROM dbo.Customers", connection);
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
builder.QuotePrefix = "[";
builder.QuoteSuffix = "]";

DataSet custDS = new DataSet();

connection.Open();
adapter.Fill(custDS, "Customers");

// Code to modify data in the DataSet here.

// Without the SqlCommandBuilder, this line would fail.
adapter.Update(custDS, "Customers");
connection.Close();

二、使用 DataAdapter 更新數據源

需要注意:

a)如果 SelectCommand 返回 OUTER JOIN 的結果,則 DataAdapter 不會為生成的 DataTable 設置 PrimaryKey 值。您必須自己定義PrimaryKey 以確保正確解析重復行.

b)如果對 DataSet、DataTable 或 DataRow 調用 AcceptChanges,則將使 DataRow 的所有 Original 值都將被重寫為該 DataRow 的 Current 值。如果已修改將該行標識為唯一行的字段值,那么當調用 AcceptChanges 后,Original 值將不再匹配數據源中的值。

看看下面例子:

// Assumes connection is a valid SqlConnection.
SqlDataAdapter dataAdpater = new SqlDataAdapter(
"SELECT CategoryID, CategoryName FROM Categories", connection);

dataAdpater.UpdateCommand = new SqlCommand(
"UPDATE Categories SET CategoryName = @CategoryName " +
"WHERE CategoryID = @CategoryID" , connection);

dataAdpater.UpdateCommand.Parameters.Add(
"@CategoryName", SqlDbType.NVarChar, 15, "CategoryName");

SqlParameter parameter = dataAdpater.UpdateCommand.Parameters.Add(
"@CategoryID", SqlDbType.Int);
parameter.SourceColumn = "CategoryID";
parameter.SourceVersion = DataRowVersion.Original;

DataSet dataSet = new DataSet();
dataAdpater.Fill(dataSet, "Categories");

DataRow row = dataSet.Tables["Categories"].Rows[0];
row ["CategoryName"] = "New Category";

dataAdpater.Update(dataSet, "Categories");

插入、更新和刪除的排序

在許多情況下,以何種順序向數據源發(fā)送通過 DataSet 作出的更改是相當重要的。
例如,如果已更新現(xiàn)有行的主鍵值并且添加了具有新主鍵值的新行,則務必要在處理插入之前處理更新。

可以使用 DataTable 的 Select 方法來返回僅引用具有特定 RowState 的 DataRow 數組。然后可以將返回的 DataRow 數組傳遞到 DataAdapter 的 Update 方法來處理已修改的行。通過指定要更新的行的子集,可以控制處理插入、更新和刪除的順序。

示例如下:

DataTable table = dataSet.Tables["Customers"];
// First process deletes.
adapter.Update(table.Select(null, null, DataViewRowState.Deleted));
// Next process updates.
adapter.Update(table.Select(null, null, 
DataViewRowState.ModifiedCurrent));
// Finally, process inserts.
adapter.Update(table.Select(null, null, DataViewRowState.Added));

三、使用sql語句更新

例如:

cmd = new OleDbCommand(string.Format(@"insert into worker(workerid,workername,password,phoneno) values ('{0}','{1}','{2}','{3}') ", textBox1.Text, textBox2.Text, textBox3.Text, textBox4.Text),oc);
oc.Open();
try
{
 int i = cmd.ExecuteNonQuery();
}
catch (Exception ex)
{

}

性能的優(yōu)劣及使用的情形,還未完全明白。

一般的,綁定bindingsource,用datatable綁定bindingsource (實質上綁定的是datatable。defaultview,同時可用到dataview的篩選功能,但是在篩選完后,filter要重置為null,否則出現(xiàn)的一直是經過篩選的數據)

其他:

使用builder 的作用:

OleDbCommandBuilder cb = new OleDbCommandBuilder(da);

這個主要是為了讓C#自動為OleDbDataAdapter da生成相對應的DeleteCommand,UpdateCommand!

希望本文所述對大家的C#數據庫程序設計有所幫助。

相關文章

  • c# 異步編程入門

    c# 異步編程入門

    這篇文章主要介紹了c# 異步編程入門的相關資料,幫助大家更好的理解和學習使用c#,感興趣的朋友可以了解下
    2021-03-03
  • C#表達式樹基礎教程

    C#表達式樹基礎教程

    這篇文章介紹了C#表達式樹的基礎教程,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • 基于不要返回null之EmptyFactory的應用詳解

    基于不要返回null之EmptyFactory的應用詳解

    本篇文章對不要返回null之EmptyFactory進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • 字符串陣列String[]轉換為整型陣列Int[]的實例

    字符串陣列String[]轉換為整型陣列Int[]的實例

    下面小編就為大家分享一篇字符串陣列String[]轉換為整型陣列Int[]的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • C#遞歸方法實現(xiàn)無限級分類顯示效果實例

    C#遞歸方法實現(xiàn)無限級分類顯示效果實例

    這篇文章主要介紹了C#遞歸方法實現(xiàn)無限級分類顯示效果,結合完整實例形式分析了C#遞歸算法與數據元素遍歷的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2016-06-06
  • C#實現(xiàn)簡單打字游戲

    C#實現(xiàn)簡單打字游戲

    這篇文章主要為大家詳細介紹了C#實現(xiàn)簡單打字游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • Unity實現(xiàn)相機截圖功能

    Unity實現(xiàn)相機截圖功能

    這篇文章主要為大家詳細介紹了Unity實現(xiàn)相機截圖功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • Unity圖形學之ShaderLab入門基礎

    Unity圖形學之ShaderLab入門基礎

    Unity中所有Shader文件都通過一種陳述性語言進行描述,稱為“ShaderLab”, 這篇文章主要介紹了Unity圖形學之ShaderLab入門基礎,需要的朋友可以參考下
    2022-01-01
  • WPF中ImageBrush常用方式介紹

    WPF中ImageBrush常用方式介紹

    這篇文章介紹了WPF中ImageBrush的常用方式,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • C# Double轉化為String時的保留位數及格式方式

    C# Double轉化為String時的保留位數及格式方式

    這篇文章主要介紹了C# Double轉化為String時的保留位數及格式方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02

最新評論