C#/.NET使用HttpWebRequest、SqlBulkCopy從API獲取數據批量插入DB

来源:http://www.cnblogs.com/xurongjian/archive/2016/04/18/5406129.html
-Advertisement-
Play Games

小弟新手程式員一枚,代碼技術和文章水平均不才。所寫文章均為對自己所寫所學代碼的簡單記錄,可能對於老手程式員營養價值不高,望莫見怪。 我工作上有個需求:從某處API介面上獲取數據(大約1W條而已)並插入到資料庫中。 樓主剛畢業菜鳥,沒做過批量插入操作。藉助baidu搜索得知SqlBulkCopy可以實 ...


  小弟新手程式員一枚,代碼技術和文章水平均不才。所寫文章均為對自己所寫所學代碼的簡單記錄,可能對於老手程式員營養價值不高,望莫見怪。

  

  我工作上有個需求:從某處API介面上獲取數據(大約1W條而已)並插入到資料庫中。

  樓主剛畢業菜鳥,沒做過批量插入操作。藉助baidu搜索得知SqlBulkCopy可以實現。SqlBulkCopy相關的原理,我現在還沒瞭解就不擺弄了,以後補上!

  (不要問為什麼不用google,公司內網就連msdn.microsoft.com都不給上!另外我公司是開發C#/.NET的,不是JAVA。 )

  

  首先,要從介面獲取數據自然少不了發送請求,將XML格式的數據放入記憶體表DataTable中。 

  

     #region 發送HTTP獲取數據
        /// <summary>
        /// 發送HTTP獲取數據
        /// </summary>
        /// <param name="url">介面地址</param>
        /// <param name="method">介面方法</param>
        /// <returns></returns>
        public DataTable GetDataAsTabel(string url, string method)
        {
            DataSet ds = new System.Data.DataSet();
            try
            {
                HttpWebRequest request = HttpWebRequest.Create(url + method) as HttpWebRequest;
                request.Method = "GET";
                WebResponse response = request.GetResponse();
                Stream stream = response.GetResponseStream();
                string str = "";
                using (StreamReader sr = new StreamReader(stream))
                {
                    str = sr.ReadToEnd();
                }
                str.Trim();
                ds.ReadXml(new StringReader(str), System.Data.XmlReadMode.Auto);
                return ds.Tables[0];
            }
            catch (Exception ex)
            {
                MessageBox.Show("GetDataAsTabel方法出錯:" + ex.Message);
                return null;
            }
        }
        #endregion

 

  其次,使用SqlBulkCopy類把數據放資料庫。SqlBulkCopy.WriteToServer()提供了4種重載方式,如下:

  public void WriteToServer(DataRow[] rows);

  public void WriteToServer(DataTable table);

  public void WriteToServer(IDataReader reader);

  public void WriteToServer(DataTable table, DataRowState rowState);

 

  顯然第二種最簡單粗暴,大家都喜歡的。也就是上面的代碼為什麼要返回DataTable了。在新建SqlBulkCopy實例時,可以由SqlBulkCopyOptions來設置插入時的檢查約束、鎖表、觸發器、每批次事務等操作。sqlBC.DestinationTableName是DB中要插入數據的表名。sqlBC.BatchSize是每一批次放入資料庫的數據量。

  預設情況下,SqlBulkCopy會認為源數據DataTable的列與目標表的列是一一對應的,一旦兩者有所不同(列數或列名不一致)則會插入失敗並報錯。所以,我們需要用public SqlBulkCopyColumnMapping Add(string sourceColumn, string destinationColumn)來添加源列名與目標列名的對應關係。數據格式不用做匹配,SqlBulkCopy會幫忙轉換。當然,用非時間格式的string轉換成DateTime這種情況毫無疑問的報錯。最後,qlBC.WriteToServer()收工。

    #region 把數據寫入資料庫
        /// <summary>
        /// 把數據寫入資料庫
        /// </summary>
        /// <param name="tableName">資料庫表名</param>
        /// <param name="dt">數據</param>
        /// <returns></returns>
        public bool WriteToServer(string tableName,DataTable dt)
        {
            bool execResult = false;
            SqlConnection sqlCon = new SqlConnection(SqlConnectionString);
            sqlCon.Open();
            SqlTransaction sqlTran = sqlCon.BeginTransaction(); // 開始事務
            SqlBulkCopy sqlBC = new SqlBulkCopy(sqlCon, SqlBulkCopyOptions.Default, sqlTran);
            sqlBC.DestinationTableName = tableName;
            sqlBC.BatchSize = 10000;
            for (int i = 0; i < dt.Columns.Count; i++)
            {
                sqlBC.ColumnMappings.Add(dt.Columns[i].ColumnName,dt.Columns[i].ColumnName);
            }
            try
            {
                sqlBC.WriteToServer(dt);
                sqlTran.Commit();
                execResult = true;
            }
            catch (Exception ex)
            {
                execResult = false;
                sqlTran.Rollback();
                MessageBox.Show("資料庫錯誤:" + ex.Message);
            }
            finally
            {
                sqlBC.Close();
                sqlCon.Close();
            }
            return execResult;
        }
        #endregion

 

  相關文章:http://www.cnblogs.com/zfanlong1314/archive/2013/02/05/2892998.html 

  既是推薦也是我自己的mark。

 


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

-Advertisement-
Play Games
更多相關文章
  • 在ASP.NET中,頁面間數據傳遞的方法有很多。下麵為大家總結一下,頁面間數據傳遞的方法。 Web頁面是無狀態的,伺服器對每一次請求都認為來自不同用戶,因此,變數的狀態在連續對同一頁面的多次請求之間或在頁面跳轉時不會被保留。在 用ASP.NET 設計開發一個Web系統時, 遇到一個重要的問題是如何保 ...
  • 前言 作為一名.NET程式員,很多時候都會被什麼拖控制項、跨平臺等字眼所鄙視過,但是在我的的內心還是沒有把自己看低過。因為說到底,平臺和語言只是我們吃飯的工具。很多時候公司的發展是取決於商業競爭的,微軟也不例外。在大環境下,我們終於看到了微軟給我們帶來的跨平臺的驚喜。儘管這隻是剛剛開始,但我相信在不久 ...
  • 本來是想試著做一個簡單OA項目玩玩的,真是不做不知道,一做嚇死人,原來以為很簡單的事情,但是做起來不是忘這就是忘那的,有的技術還得重新溫習。所以還是得記錄。免得哪天電腦掛了,就全沒有了。 開始是看了園子里何鎮汐的一系列文章,寫的太好了,只看了幾篇就有想寫代碼的衝動,很大一部分都是搬他的東西。但是我還 ...
  • 關於寄宿和AppDomain 微軟開發CLR時,將它實現成包含在一個DLL中的COM伺服器。 任何Windows應用程式都能寄宿(容納)CLR。(簡單來講,就是CLR在一個DLL中,通過引用這個DLL,可以實現包含CLR) CLR COM伺服器初始化會創建一個預設AppDomain,這個AppDom ...
  • 【ASP.NET實戰教程】ASP.NET實戰教程大集合,各種項目實戰集合,希望大家可以好好學習教程中,有的比較老了,但是一直很經典!!!!論壇中很多小伙伴說.net沒有實戰教程學習,所以小編連夜搜集整理出一些比較好的教程,望君好好珍惜,資源不易,且保持,且珍惜直接上資源截圖:下載地址【回覆可見】:h ...
  • 歲末主推:牛牛老師主講,多用戶博客系統,基於ASP.NET技術,年後將帶來移動業務平臺項目項目目標: 打造個性品牌Blogo,定製多用戶博客 為每一個博客用戶提供個性化的 blogo解決方案,打造精品blogo門戶網站 環境:VS2008+SQL Server2005 【小編推薦:現在學習可以使用 ...
  • .Net進銷存系統詳細課程大綱(開發工具採用VS2008+sqlsever2005) 【小編提醒:現在學習的話,可以使用vs2012+sql 2008 學習的是思路,教學環境不一定要一模一樣】1.項目概況及項目開發流程: 課程目標: ·瞭解項目相關各類情況,對項目開發及本項目有個總體認識 主要內容: ...
  • 1、上傳永久圖片素材,註意構造請求頭部信息時name="media"就行了 視圖代碼: @using (Html.BeginForm("UploadFile", "MenuConfig", FormMethod.Post, new { enctype = "multipart/form-data" ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...