日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

C#數(shù)據(jù)適配器DataAdapter_C#教程

作者:springsnow ? 更新時(shí)間: 2022-07-06 編程語言

一、填充數(shù)據(jù)

DataSet ds = new DataSet();
SqlCommand cmd = new SqlCommand("select * from Catogories;select * from Customers", conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);//da可以多次使用于不同的SelectCommand.CommandText
DataTableMapping map = da.TableMappings.Add("Table", "Customer");//參數(shù)依次為,數(shù)據(jù)源中表,DataSet中的表
map.ColumnMappings.Add("Name", "CustomerName");
//da.MissingMappingAction= MissingMappingAction.Ignore;
da.MissingSchemaAction = MissingSchemaAction.AddWithKey;//用于處理模式?jīng)_突,默認(rèn)為Add。
da.Fill(ds);//新增的DataTable表名默認(rèn)為"Table",而后新增的表名默認(rèn)為Table1,Table2等。
da.Fill(ds, "Customer");
da.Fill(ds, 0, 10000, "Customer");//用于分頁填充
da.FillSchema(ds, System.Data.SchemaType.Source, "Customer");//僅僅填充模式信息

如果連接未打開,則會自動打開,F(xiàn)ill后自動關(guān)閉,如還需要使用此連接,需要重新打開。如果conn手工已打開,F(xiàn)ill后需要手動關(guān)閉連接。

二、將多個DataTable插入Tables集合

1、使用多個DataAdapter填充

SqlCommand cmd = new SqlCommand("select * from Catogories;s", conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds, "Catogories");

cmd.CommandText = "select * from Customers";
SqlDataAdapter da2 = new SqlDataAdapter(cmd);
da2.Fill(ds, "Customer");

2、使用同一個DataAdapter,用不同的SelectCommandText填充

SqlCommand cmd = new SqlCommand("select * from Catogories;s", conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds, "Catogories")

da.SelectCommand.CommandText = "select * from Customers";
da.Fill(ds, "Customer");

3、返回多個結(jié)果集的SQL(推薦)

SqlCommand cmd = new SqlCommand("select * from Catogories;select * from Customers", conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds);

三、使用DataAdapter更新數(shù)據(jù)

DataSet dsChanged = ds.GetChanges();
if (dsChanged != null)
{
    SqlCommandBuilder builder=new SqlCommandBuilder(da);
    //自動生成InsertCommand,UpdateCommand,DeleteCommand命令,前提是:Select語句為單表,同時(shí)此語句包含主鍵或唯一列
    da.Update(ds,"Author");//Update方法檢測DataSet中的每條記錄,如果行狀態(tài)不為Unchanaged,根據(jù)其行狀態(tài)調(diào)用不同的SQL語句。
    ds.AcceptChanges();
}
  • DataTable.AcceptChanges方法:提交自上次調(diào)用AcceptChanges以來對該表進(jìn)行的所有更改。??
    所有Added和Modified行成為Unchanged;Deleted行被移除。??
  • DataTable.RejectChanges方法:回滾自該表加載以來或上次調(diào)用AcceptChanges以來對該表進(jìn)行的所有更改。??
    Added被移除。DataRowState為Modified或Deleted的行返回到其初始狀態(tài)。?

四、使用SQL

OleDbDataAdapter da = new OleDbDataAdapter();
OleDbCommand cmd = new OleDbCommand("insert into  [A_Emp_Dept_20190522](empname,line) values (?,?)", conn);
cmd.Parameters.Add(new OleDbParameter("empname", OleDbType.Char, 11, ParameterDirection.Input, false, 0, 0, "empname", DataRowVersion.Current, null));
cmd.Parameters.Add(new OleDbParameter("line", OleDbType.Char, 11, ParameterDirection.Input, false, 0, 0, "line", DataRowVersion.Current, null));
da.InsertCommand = cmd;
//da.InsertCommand.UpdatedRowSource= UpdateRowSource.Both;
DataSet ds = new DataSet();
DataRow row = ds.Tables[0].NewRow();
row["empname"] = "222";
row["line"] = "FBd";
ds.Tables[0].Rows.Add(row);
da.Update(ds);

UpdatedRowSource

  • Both:輸出參數(shù)和返回的結(jié)果集的第一行都可以映射到 DataSet 中已更改的行。
    FirstReturnedRecord:只有返回的結(jié)果集的第一行中的數(shù)據(jù)才可以映射到 DataSet 中已更改的行。
    None:忽略任何輸出參數(shù)或返回的結(jié)果集中的行。
    OutputParameters:只有輸出參數(shù)才可以映射到 DataSet 中已更改的行

五、DataAdapter事件

  • RowUpdating:在對數(shù)據(jù)源執(zhí)行命令前的 Update(DataSet) 過程中發(fā)生。
  • RowUpdated:在對數(shù)據(jù)源執(zhí)行命令后的 Update(DataSet) 過程中發(fā)生。

SqlRowUpdatedEventArgs 類屬性

  • Command:獲取或設(shè)置當(dāng)調(diào)用 SqlCommand 時(shí)執(zhí)行的 Update(DataSet)。
  • Errors:獲取當(dāng) Command 執(zhí)行時(shí) .NET Framework 數(shù)據(jù)提供程序生成的任何錯誤。?
  • RecordsAffected:通過執(zhí)行 SQL 語句獲取更改、插入或刪除的行數(shù)。?
  • Row:獲取通過 Update(DataSet) 發(fā)送的 DataRow。?
  • RowCount:獲取在一批更新記錄中處理的行數(shù)。?
  • StatementType:獲取所執(zhí)行的 SQL 語句的類型。?
  • Status:獲取 Command 屬性的 UpdateStatus。?
  • TableMapping:獲取通過 Update(DataSet) 發(fā)送的 DataTableMapping。

原文鏈接:https://www.cnblogs.com/springsnow/p/9433912.html

欄目分類
最近更新