由于服务器需要为每个数据库建立连接,因此我在SO中找到的答案根本不起作用。 对于某些表,我必须在复制行之前进行一些计算,但有些我可以复制整个表。最后,我写的是我的程序中的自动化。
Oldcn是旧数据库的连接,Newcn是新数据库的连接。
对于我可以复制的表格,我在下面写了这个程序。
做这项工作还有更好的方法吗? (它适用于背景)
private string[] CopyTva(MySqlConnection Oldcn, MySqlConnection Newcn, string[] res, DoWorkEventArgs we,string msg)
{
int counter = int.Parse(res[1]);
MySqlCommand cmd = new MySqlCommand("SELECT * FROM tvaval", Oldcn);
MySqlCommand cmd1 = new MySqlCommand("INSERT INTO tvaval (id,tvavalue,cr_user,cr_date,up_user,up_date) VALUES (@id,@tvavalue,@cr_user,@cr_date,@up_user,@up_date)", Newcn);
MySqlDataReader rd = null;
try
{
rd = cmd.ExecuteReader();
while (rd.Read())
{
cmd1.Parameters.AddWithValue("@id", rd["id"].ToString());
//bla bla same as above
try
{
cmd1.ExecuteNonQuery();
}
catch (MySqlException e)
{
rd.Dispose();
res[2] = "Erreur:TVA " + e.Message.ToString();
return res;
}
++counter;
bgw.ReportProgress((counter * 100) / DbTotalRow,msg);
cmd1.Parameters.Clear();
}
rd.Dispose();
}
catch (MySqlException e)
{
res[2] = "Erreur:TVA " + e.Message.ToString();
return res;
}
res[0] = "1";res[1] = counter.ToString();res[2] = "";
return res;
}
答案 0 :(得分:0)
MySQL不需要为每个数据库单独连接。连接具有默认数据库,但您可以在表名之前显式指定数据库名称,这将覆盖默认值。所以你可以用一个查询来做到这一点:
INSERT INTO newdb.tvaval
SELECT * FROM olddb.tvaval