網(wǎng)站首頁 編程語言 正文
一、填充數(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
相關(guān)推薦
- 2022-07-01 python讀取nc數(shù)據(jù)并繪圖的方法實(shí)例_python
- 2022-04-07 React中代碼分割的4種實(shí)現(xiàn)方式_React
- 2023-10-16 獲取當(dāng)月的月初和月末日期時(shí)間戳
- 2022-09-22 elementui select選擇器獲取選中拿到當(dāng)前對象
- 2022-11-05 swift語言AutoreleasePool原理及使用場景_Swift
- 2022-08-30 C++逐步介紹日期類的使用_C 語言
- 2022-08-12 C#實(shí)現(xiàn)簡單的字符串加密_C#教程
- 2022-12-12 使用PlatformView將?Android?控件view制作成Flutter插件_Android
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支