C#实现复制数据库 C#将A数据库数据转到B数据库
作者:至浊至愚 时间:2024-01-23 11:56:09
本文章以一个表为例,要转多个表则可将DataSet关联多个表,下面给出完整代码,包括引用以及main函数与复制函数。
要说明的是,必须先用Sql语句复制表结构,才能顺利的使用以下代码复制数据。
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)
{
//要复制的表名
string table = "V_Position";
//构造连接字符串
SqlConnectionStringBuilder builder1 = new SqlConnectionStringBuilder();
builder1.DataSource = ".\\CANFLY"; //实例名称为CANFLY
builder1.InitialCatalog = "desdata"; //目标数据库
builder1.IntegratedSecurity = true; //使用Windows身份验证
SqlConnectionStringBuilder builder2 = new SqlConnectionStringBuilder();
builder2.DataSource = ".\\CANFLY";
builder2.InitialCatalog = "bddata"; //源数据库
builder2.IntegratedSecurity = true;
//调用复制数据库函数
InsertTable(builder1.ConnectionString, builder2.ConnectionString, table);
}
//参数为两个数据库的连接字符串
private static void InsertTable(string conString1, string conString2, string tabStr)
{
//连接数据库
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);
}
//复制数据
for (int j = 0; j < dataSet2.Tables[0].Rows.Count; j++)
{
dataSet1.Tables[0].LoadDataRow(dataSet2.Tables[0].Rows[j].ItemArray, false);
}
//将DataSet变换显示在与其关联的目标数据库
SqlCommandBuilder cb = new SqlCommandBuilder(adapter1);
adapter1.Update(dataSet1, tabStr);
cb.RefreshSchema();
Console.WriteLine("表" + tabStr + "复制成功!");
conn1.Close();
conn2.Close();
}
}
}
来源:http://blog.csdn.net/u011421608/article/details/39957873
标签:C#,复制,数据库


猜你喜欢
sqlserver存储过程语法详解
2024-01-21 04:43:53
Python实现树的先序、中序、后序排序算法示例
2022-12-26 04:00:18
使用豆瓣提供的国内pypi源 <font color=red>原创</font>
2023-05-31 20:39:09
Js中var,let,const的区别你知道吗
2024-05-09 15:07:50
C#三种判断数据库中取出的字段值是否为空(NULL) 的方法
2024-01-22 06:57:17
pytorch中的自定义反向传播,求导实例
2021-08-07 06:57:53
MySQL性能优化的最佳20+条经验
2024-01-27 15:25:06

pandas实现DataFrame显示最大行列,不省略显示实例
2023-10-27 14:08:52
Windows 下 MySQL 8.X 的安装教程
2024-01-14 03:05:33

mssql查找备注(text,ntext)类型字段为空的方法
2024-01-28 04:13:18
利用numpy和pandas处理csv文件中的时间方法
2023-01-21 09:44:56

django初始化数据库的实例
2023-09-19 07:35:47
django form和field具体方法和属性说明
2023-07-24 11:22:45
设计72变——寻求banner制作的变化
2009-11-12 12:56:00

Oracle 数据库导出(exp)导入(imp)说明
2009-03-06 10:49:00
Pycharm学习教程(2) 代码风格
2022-03-21 08:38:31

python实现requests发送/上传多个文件的示例
2023-07-23 01:42:39
Python利用三层神经网络实现手写数字分类详解
2023-10-06 19:53:40

Python使用Asyncio实现检查网站状态
2023-01-23 18:56:39
Mysql中错误使用SQL语句Groupby被兼容的情况
2024-01-16 03:55:10
