利用OracleCommandBuilder實現 datatable與資料庫的增刪改

来源:https://www.cnblogs.com/wxdgis/archive/2018/01/11/8270482.html
-Advertisement-
Play Games

這個資料庫交互的類我是以單例模式實現的,"_"開頭的都是已經生成唯一的實例。 舊數據用sql語句查詢出的dataTable,發生改變後dataTable(增加,刪除,修改),增改是利用OracleCommandBuilder自身Update(table),它可以實現增加和修改(需要主鍵)。 刪除是利 ...


 

這個資料庫交互的類我是以單例模式實現的,"_"開頭的都是已經生成唯一的實例。

舊數據用sql語句查詢出的dataTable,發生改變後dataTable(增加,刪除,修改),增改是利用OracleCommandBuilder自身Update(table),它可以實現增加和修改(需要主鍵)。

刪除是利用舊datable與修改後的datable之間取交差,獲取需要刪除的數據。

 

/// <summary>
/// datatable與資料庫的增刪改的實現
/// </summary>
/// <param name="table"></param>
/// <param name="CommandText">sql語句</param>
/// <param name="key"></param>
/// <param name="tableName"></param>
/// <returns></returns>
public int UpdateAndDeleteTable(DataTable table, string CommandText,string key,string tableName)
{
//更新和新增
OracleCommandBuilder ocb = new OracleCommandBuilder(_oracleDataAdapter);
_oracleDataAdapter.SelectCommand.CommandText = CommandText;
_oracleDataAdapter.InsertCommand = ocb.GetInsertCommand();
int updete=_oracleDataAdapter.Update(table);
//刪除:差集刪除
DataTable oldTable = this.GetDataTable(CommandText);
var query = oldTable.AsEnumerable().Except(table.AsEnumerable(), DataRowComparer.Default);
if (query.Count()==0)
{
return updete;
}
StringBuilder sb = new StringBuilder();
sb.Append($"delete {tableName} where {key} in(");

foreach (var row in query)
{
sb.Append("'"+row[key].ToString()+"',");
}
sb.Remove(sb.Length - 1, 1);
sb.Append(")");
string sql = sb.ToString();
int delete = ExcuteSql(sql);
return updete+ delete;
}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 相關介紹:  樹(英語:tree)是一種抽象數據類型(ADT)或是作這種抽象數據類型的數據結構,用來模擬具有樹狀結構性質的數據集合。它是由n(n 0)個有限節點組成的一個具有層次關係的集合。把它叫做“樹”是因為它看起來像一棵倒掛的樹,也就是說它是根朝上,而葉朝下的。樹形結構中數據元素之間具 ...
  • 前言:在Spring中可以通過對方法進行事務的配置,而不是像原來通過手動寫代碼的方式實現事務的操作,這在很大程度上減少了開發的難度,本文介紹Spring事務配置的兩種方式:基於配置文件的方式和基於註解的方式。並對配置過程中可能出現的問題作出總結。 一、基於配置文件的方式,具體如下: 註:配置文件中, ...
  • 接觸Java第三天,嘿嘿,今天近代史期末考試,提前一小時交卷,回宿舍繼續學習,中午去見女神姐姐了,每次見完女神姐姐都是滿滿地動力。這次女神姐姐告訴我們要好好規劃自己的時間,早上花20分鐘規劃好一天的時間安排,晚上睡覺前做個小總結。當你覺得你一天都在忙,但卻不知道自己在忙什麼的時候,就應該總結一下,就 ...
  • 為了理解函數提升,讓我們從以下代碼開啟我們的學習之旅: 應該輸出什麼呢? 在任何其他編程語言中,這裡的輸出將會是reference error。但是,在JavaScript中,你將得到undefined作為輸出。為什麼?因為JavaScript會提升變數到執行上下文的頂部。執行上下文可以是聲明變數的 ...
  • 前言 即便想 nginx 這麼牛B的伺服器, 也不能保證他不掛啊, 就算不是機器出故障, 比如, 停電了, 那麼機器掛了, 很正常啊. 這時候, 沒有分發伺服器, 網站就不能正常訪問了, 咋搞? 網站不開了, 大家放假回家咯! - 不錯的辦法啊. 我們想回家, 但是老闆不許, 沒辦法, 加個備份機吧 ...
  • 前言 前面虛擬主機的部分, 發現我所有的修改, 都是對 nginx 目錄下, nginx.conf 和 html 文件夾的操作. 我的最終目的, 是映射到不同電腦的tomcat裡面去啊, 操作這裡的html 怕是不能實現我的功能了. 這時候, 需要來修改配置文件了. 一. 概念介紹 1. 反向代理 ...
  • 前言 前面提到過, 由nginx來分發請求到tomcat中, 那麼怎麼來區分這些tomcat呢? 我們一般訪問網站的時候, 是不是可以使用 ip : port (127.0.0.1:8080)的方式來訪問, 或者是 功能變數名稱 : port (www.baidu.com:80), 只不過這裡可以不寫埠, ...
  • 一.換膚功能 1. 添加 DevExpress.OfficeSkins 和 DevExpress.BonusSkins 兩個引用 2. 皮膚註冊 DevExpress.UserSkins.BonusSkins.Register(); DevExpress.Skins.SkinManager.Enab ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...