private void Form1_Load(object sender, EventArgs e)
{
BindDataBase(combDataBaseNew, , "");
BindDataBase(combDataBaseOld, , ""); }
//获取新数据库 0 是数据库 1是 表
private void BindDataBase(ComboBox combDataBase, int style, string database)
{
switch (style)
{
case :
{
string strSql = "select name from sysdatabases order by name";
combDataBase.DataSource = this.GetDataBases(strSql).Tables[];
combDataBase.DisplayMember = "name";
combDataBase.ValueMember = "name";
break;
}
case :
{
StringBuilder sb = new StringBuilder();
sb.AppendFormat("use {0}", database);
sb.AppendFormat(" SELECT Name from sysobjects Where Type='U' ORDER BY Name");
combDataBase.DataSource = this.GetDataBases(sb.ToString()).Tables[];
combDataBase.ValueMember = "name";
combDataBase.DisplayMember = "name";
break;
}
}
}
//获取数据库连接
private SqlConnection GetConnections()
{
SqlConnectionStringBuilder sqlsb = new SqlConnectionStringBuilder();
sqlsb.DataSource = "localhost";
sqlsb.IntegratedSecurity = true;
SqlConnection conn = new SqlConnection();
conn.ConnectionString = sqlsb.ConnectionString;
return conn;
}
//根据查询语句,获取对应的数据集
private DataSet GetDataBases(string strSql)
{
SqlDataAdapter sda = new SqlDataAdapter();
SqlCommand cmd = new SqlCommand();
DataSet ds = new DataSet();
using (SqlConnection conn = this.GetConnections())
{
conn.Open();
cmd.CommandText = strSql;
cmd.CommandType = CommandType.Text;
cmd.Connection = conn;
sda.SelectCommand = cmd;
sda.Fill(ds, "databases");
conn.Close() ; }
return ds;
}
private int GetDoIt(string strSql)
{
SqlCommand cmd = new SqlCommand();
object b = null;
using (SqlConnection conn = this.GetConnections())
{
conn.Open();
cmd.CommandText = strSql;
cmd.CommandType = CommandType.Text;
cmd.Connection = conn;
b= cmd.ExecuteNonQuery();
conn.Close();
}
return Convert.ToInt32(b);
}
private void btn_biaoOld_Click(object sender, EventArgs e)
{
BindDataBase(comOldtable, , combDataBaseOld.SelectedValue.ToString()); } private void btn_biaoNew_Click(object sender, EventArgs e)
{
BindDataBase(comNewtable, , combDataBaseNew.SelectedValue.ToString());
}
//绑定grid控件
public void GetTableZiDuan()
{
string strSql = string.Format("use {0} Select Name FROM SysColumns Where id=Object_Id('{1}')", combDataBaseOld.SelectedValue, comOldtable.SelectedValue);
this.dataGridView1.DataSource = GetDataBases(strSql).Tables[]; }
//绑定combobox控件
public void GetNewTableZiDuan()
{
string strSql = string.Format("use {0} Select Name FROM SysColumns Where id=Object_Id('{1}')", combDataBaseNew.SelectedValue, comNewtable.SelectedValue);
this.NewZiDuan.DataSource = GetDataBases(strSql).Tables[];
this.NewZiDuan.ValueMember = "name";
this.NewZiDuan.DisplayMember = "name";
}
private void btn_OldZiDuan_Click(object sender, EventArgs e)
{
GetTableZiDuan();
} private void btn_NewZiDuan_Click(object sender, EventArgs e)
{
GetNewTableZiDuan();
}
private void dataGridView1_DataBindingComplete(object sender, DataGridViewBindingCompleteEventArgs e)
{
if (this.dataGridView1.Rows.Count != )
{
for (int i = ; i < this.dataGridView1.Rows.Count; )
{
this.dataGridView1.Rows[i].DefaultCellStyle.BackColor = System.Drawing.Color.Pink;
i += ;
}
}
} private void btn_StartZhuanLu_Click(object sender, EventArgs e)
{
List<string> oldList = new List<string>();
List<string> newList = new List<string>();
for (int i = ; i < this.dataGridView1.Rows.Count; i++)
{
if ((bool)(((DataGridViewCheckBoxCell)this.dataGridView1.Rows[i].Cells["isTrue"]).EditedFormattedValue) == true)
{
oldList.Add(dataGridView1.Rows[i].Cells["OldZiDuan"].Value.ToString());
newList.Add(((DataGridViewComboBoxCell)dataGridView1.Rows[i].Cells["NewZiDuan"]).Value.ToString());
}
}
OldToNew(oldList,newList,"");
}
private void OldToNew(List<string> oldList, List<string> newList, string where)
{
StringBuilder sb = new StringBuilder();
sb.AppendFormat("use {0}",combDataBaseOld.SelectedValue);
sb.AppendFormat(" select ");
for (int i = ; i < oldList.Count; i++)
{
sb.AppendFormat(oldList[i] + ",");
}
sb.Remove(sb.ToString().LastIndexOf(','), );
sb.AppendFormat(" from {0}", comOldtable.SelectedValue);
if (!string.IsNullOrEmpty(where))
{
sb.AppendFormat(" where {0}", where);
}
MessageBox.Show(sb.ToString());
DataTable dt= GetDataBases(sb.ToString()).Tables[];
if (dt.Rows.Count > )
{
int sum = ;
for (int i = ; i < dt.Rows.Count; i++)
{
sum+=InsertNewDataBase(dt,i,newList,oldList);
}
if (sum == dt.Rows.Count)
{
MessageBox.Show("数据转录成功");
}
else
{
if (sum != )
{
MessageBox.Show("理论转录信息条数:" + dt.Rows.Count + ";实践转录信息条数:" + sum + ";实际转录条数与理论条数不符");
} }
}
else
{
MessageBox.Show("要转录的旧数据库,没有数据信息");
}
}
private int InsertNewDataBase(DataTable dt,int a,List<string> newList,List<string> oldList)
{
int sum = ;
try
{
StringBuilder sb = new StringBuilder();
sb.AppendFormat("use {0}", combDataBaseNew.SelectedValue);
sb.AppendFormat(" insert into {0} (", comNewtable.SelectedValue);
for (int i = ; i < newList.Count; i++)
{
sb.AppendFormat(newList[i] + ",");
}
sb.Remove(sb.ToString().LastIndexOf(','), );
sb.AppendFormat(")values(");
for (int i = ; i < oldList.Count; i++)
{
sb.AppendFormat("'" + dt.Rows[a][oldList[i]] + "'" + ",");
}
sb.Remove(sb.ToString().LastIndexOf(','), );
sb.AppendFormat(")");
MessageBox.Show(sb.ToString());
sum = GetDoIt(sb.ToString());
return sum;
}
catch (Exception e)
{
MessageBox.Show(e.Message);
return sum;
} }
}

sql数据库之间数据的转录的更多相关文章

  1. 不同版本的SQL Server之间数据导出导入的方法及性能比较

    原文:不同版本的SQL Server之间数据导出导入的方法及性能比较 工作中有段时间常常涉及到不同版本的数据库间导出导入数据的问题,索性整理一下,并简单比较下性能,有所遗漏的方法也欢迎讨论.补充. 0 ...

  2. 不同SQL数据库之间表数据的实时同步-发布与订阅

    https://blog.csdn.net/rand_muse/article/details/81326879 上述文章中,如果是实时同步,选择  事务发布即可 在快照代理 那里,不需要勾选  运行 ...

  3. oracle sql 数据库之间导入数据

    1.导入别的表 insert into EMPI_IDENTIFY select id,empiid, name||':' ||idcardno,'accidcardno','' from empi_ ...

  4. JSP Servlet SQL 三者之间数据传递

    前言: 最近一直在做WEB开发,现总结一下这一段时间的体会和感触. 切记,web开发重点在于前台数据交互,页面美化而不要太沉溺于底层数据. 浏览器时代来到,向我们召唤出更炫.更简洁.更方便.更大气的网 ...

  5. Oracle数据库之间数据同步

    这段时间负责某个项目开发的数据库管理工作,这个项目中开发库与测试数据库分离,其中某些系统表数据与基础资料数据经常需要进行同步,为方便完成指定数据表的同步操作,可以采用dblink与merge结合的方法 ...

  6. 【NIFI】 实现数据库到数据库之间数据同步

    本里需要基础知识:[NIFI] Apache NiFI 安装及简单的使用 数据同步 界面如下: 具体流程: 1.使用ExecuteSQL连接mysql数据库,通过写sql查询所需要的数据 2.nifi ...

  7. 【笔记】.NET开发环境下使用PostgreSQL+Oracle_fdw 实现两个数据库之间数据交互操作(二)

    一 新的可视化工具 因为前文所提到的,看不到外部服务器和外部表的问题,我更换了可视化工具. 好用的新工具PostgreSQL Maestro! 当然如此好用的工具不是免费的,如果想免费使用还请自己去找 ...

  8. sql 数据库 庞大数据量 需要分表

    17:04:05问下 在什么情况下 审核分区啊 ~..大熊..o○ 17:06:53这个要看应用~..大熊..o○ 17:07:37比如数据量很大,查询多是按照时间段查询,就可以用时间段来做分区~.. ...

  9. SQL不同服务器数据库之间的数据操作整理(完整版)

    ---------------------------------------------------------------------------------- -- Author : htl25 ...

随机推荐

  1. 在iframe里调用parent.func()引出的js函数运行在它们被定义的作用域里,而不是它们被执行的作用域里

    有个document里定义了一个函数func(),同时在document里嵌入了一个iframe,在这个iframe里调用父窗口的方法:parent.func(),本来我以为这个函数的运行环境是在这个 ...

  2. JS form表单提交的方法

    1.当输入用户名和密码为空的时候,需要判断.这时候就用到了校验用户名和密码,这个需要在jsp的前端页面写:有两种方法,一种是用submit提交.一种是用button提交.方法一: 在jsp的前端页面的 ...

  3. 使用微妙计算PHP脚本执行时间

    在PHP中,大多数的时间格式都是以UNIX时间戳表示的,而UNIX时间戳是以s(秒)为最小的计量时间的单位.这对某些应用程序来说不够精确,所以可以调用microtime()返回当前UNIX时间戳和微妙 ...

  4. uva 725 Division(除法)暴力法!

    uva 725  Division(除法) A - 暴力求解 Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & ...

  5. Matlab 符号运算

    root(p):多项式求根.多项式等于0时对应方程的根. 例:,则输入p=[5 4 3 2 1]; root(p) 注:多项式系数都是按幂指数递减形式的. poly([a,b,c]):求已知根为a,b ...

  6. ISO14443标准详细介绍

    这篇文章从各方面详细介绍了ISO/IEC14443标准.第一部分:物理特性1.范围ISO/IEC14443的这一部分规定了邻近卡(PICC)的物理特性.它应用于在耦合设备附近操作的ID-1型识别卡.I ...

  7. 使用GetLogicalProcessorInformation获取逻辑处理器的详细信息(NUMA节点数、物理CPU数、CPU核心数、逻辑CPU数、各级Cache)

    不过必须XP SP3以上才行.所有API大全: https://msdn.microsoft.com/en-us/library/windows/desktop/aa363804(v=vs.85).a ...

  8. 「Poetize10」封印一击

    描述 Description Nescafe由n种元素组成(编号为1~n), 第i种元素有一个封印区间[ai,bi].当封印力度E小于ai时,该元素将获得ai的封印能量:当封印力度E在ai到bi之间时 ...

  9. 网页a标签:导航制作 怎么让鼠标经过A标签的时候显示块状背景?

    文章出处:http://dongguan.seosrx.net/website/6.html

  10. javascript 关闭窗口,弹出新窗口并带有确认关闭对话框解决办法

    在很多人眼里,北京是一个物欲横流的社会,生活节奏之快,让你一丝都不能停下来,走在路上伴随着人群急速往前涌,或许有些人都不知道要去哪.也不知道自己想要的是什么?在一个浮躁的社会里,多了一些浮躁的人,到处 ...