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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...