C#實現(xiàn)復(fù)制數(shù)據(jù)庫 C#將A數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)到B數(shù)據(jù)庫
本文章以一個表為例,要轉(zhuǎn)多個表則可將DataSet關(guān)聯(lián)多個表,下面給出完整代碼,包括引用以及main函數(shù)與復(fù)制函數(shù)。
要說明的是,必須先用Sql語句復(fù)制表結(jié)構(gòu),才能順利的使用以下代碼復(fù)制數(shù)據(jù)。
using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Data; 
using System.Data.SqlClient; 
using System.Data.Common; 
 
namespace CopyData 
{ 
 class Program 
 { 
  static void Main(string[] args) 
  { 
   //要復(fù)制的表名 
   string table = "V_Position"; 
    
   //構(gòu)造連接字符串 
   SqlConnectionStringBuilder builder1 = new SqlConnectionStringBuilder(); 
   builder1.DataSource = ".\\CANFLY";  //實例名稱為CANFLY 
   builder1.InitialCatalog = "desdata"; //目標(biāo)數(shù)據(jù)庫 
   builder1.IntegratedSecurity = true;  //使用Windows身份驗證 
 
   SqlConnectionStringBuilder builder2 = new SqlConnectionStringBuilder(); 
   builder2.DataSource = ".\\CANFLY"; 
   builder2.InitialCatalog = "bddata";  //源數(shù)據(jù)庫 
   builder2.IntegratedSecurity = true; 
 
   //調(diào)用復(fù)制數(shù)據(jù)庫函數(shù) 
   InsertTable(builder1.ConnectionString, builder2.ConnectionString, table); 
  } 
   
  //參數(shù)為兩個數(shù)據(jù)庫的連接字符串 
  private static void InsertTable(string conString1, string conString2, string tabStr) 
  { 
   //連接數(shù)據(jù)庫 
   SqlConnection conn1 = new SqlConnection(); 
   conn1.ConnectionString = conString1; 
   conn1.Open(); 
 
   SqlConnection conn2 = new SqlConnection(); 
   conn2.ConnectionString = conString2; 
   conn2.Open(); 
 
   //填充DataSet1 
   SqlDataAdapter adapter1 = new SqlDataAdapter("select * from " + tabStr, conn1); 
   DataSet dataSet1 = new DataSet(); 
 
   if (dataSet1 != null) 
   { 
    adapter1.Fill(dataSet1, tabStr); 
   } 
 
   SqlDataAdapter adapter2 = new SqlDataAdapter("select * from " + tabStr, conn2); 
   DataSet dataSet2 = new DataSet(); 
 
   SqlCommand cmd2 = new SqlCommand("select count(*) from " + tabStr, conn2); 
   Object res2 = cmd2.ExecuteScalar(); 
 
   if (res2 != null) 
   { 
    int nCount = Convert.ToInt32(res2.ToString()); 
    if (nCount == 0) 
    { 
     conn1.Close(); 
     conn2.Close(); 
     return; 
    } 
   } 
 
   //填充DataSet2 
   if (dataSet2 != null) 
   { 
    adapter2.Fill(dataSet2, tabStr); 
   } 
 
   //復(fù)制數(shù)據(jù) 
   for (int j = 0; j < dataSet2.Tables[0].Rows.Count; j++) 
   { 
    dataSet1.Tables[0].LoadDataRow(dataSet2.Tables[0].Rows[j].ItemArray, false); 
   } 
 
   //將DataSet變換顯示在與其關(guān)聯(lián)的目標(biāo)數(shù)據(jù)庫 
   SqlCommandBuilder cb = new SqlCommandBuilder(adapter1); 
   adapter1.Update(dataSet1, tabStr); 
   cb.RefreshSchema(); 
 
   Console.WriteLine("表" + tabStr + "復(fù)制成功!"); 
 
   conn1.Close(); 
   conn2.Close(); 
 
  } 
 } 
} 
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
欄 目:C#教程
本文標(biāo)題:C#實現(xiàn)復(fù)制數(shù)據(jù)庫 C#將A數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)到B數(shù)據(jù)庫
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/5429.html
您可能感興趣的文章
- 01-10C#實現(xiàn)txt定位指定行完整實例
 - 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新聞效果的方法
 - 01-10C#實現(xiàn)清空回收站的方法
 - 01-10C#實現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已安裝軟件變化的方法
 - 01-10C#實現(xiàn)多線程下載文件的方法
 - 01-10C#實現(xiàn)Winform中打開網(wǎng)頁頁面的方法
 - 01-10C#實現(xiàn)遠(yuǎn)程關(guān)閉計算機或重啟計算機的方法
 - 01-10C#自定義簽名章實現(xiàn)方法
 - 01-10C#文件斷點續(xù)傳實現(xiàn)方法
 - 01-10winform實現(xiàn)創(chuàng)建最前端窗體的方法
 


閱讀排行
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
 - 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
 - 01-10WinForm限制窗體不能移到屏幕外的方法
 - 01-10WinForm繪制圓角的方法
 - 01-10C#實現(xiàn)txt定位指定行完整實例
 - 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
 - 01-10C#停止線程的方法
 - 01-10C#實現(xiàn)清空回收站的方法
 - 01-10C#通過重寫Panel改變邊框顏色與寬度的
 - 01-10C#實現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已
 
隨機閱讀
- 01-10delphi制作wav文件的方法
 - 01-10使用C語言求解撲克牌的順子及n個骰子
 - 01-11ajax實現(xiàn)頁面的局部加載
 - 08-05織夢dedecms什么時候用欄目交叉功能?
 - 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
 - 04-02jquery與jsp,用jquery
 - 01-10C#中split用法實例總結(jié)
 - 08-05DEDE織夢data目錄下的sessions文件夾有什
 - 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 


