业务需要从一个数据库复制数据到另一个数据库。当然可以一条一条的复制,但是两个数据库的表结构相同,通过操作DataSet批量复制数据到另一个数据库,不管从开发效率还是执行效率上来说是不是更好一些呢。 需要注意的点,如下: 1、数据库中必须有主键,这样
业务需要从一个数据库复制数据到另一个数据库。当然可以一条一条的复制,但是两个数据库的表结构相同,通过操作dataset批量复制数据到另一个数据库,不管从开发效率还是执行效率上来说是不是更好一些呢。
需要注意的点,如下:
1、数据库中必须有主键,这样才便于增删改查;
2、SqlDataAdapter必须放在SqlCommandBuilder中,以用于批量执行DataSet中的修改;
3、修改后的DataSet需执行AcceptChanges()方法后,才能更新DataSet,以便于下一步操作;
4、SqlDataAdapter执行Update的数据库不一定是Fill的数据库,只要表结构相同即可。
部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/
0
示例代码如下:
public void CopyData(DataSet ds, string conString, string sql, string tableName)
{
SqlConnection conn = new SqlConnection(conString);
try
{
conn.Open();
SqlDataAdapter ada = new SqlDataAdapter(sql, conn);
SqlCommandBuilder cb = new SqlCommandBuilder(ada);
DataSet destDataSet = new DataSet();
ada.Fill(destDataSet, tableName);
//Delete Rows
foreach (DataRow item in destDataSet.Tables["Pattern"].Rows)
{
item.Delete();
}
DataTable dt = null;
dt = destDataSet.Tables["Pattern"].GetChanges();
if (dt != null)
{
ada.Update(dt);
}
//Insert Rows
foreach (DataRow item in ds.Tables["Pattern"].Rows)
{
item.SetAdded();
}
dt = ds.Tables["Pattern"].GetChanges();
if (dt != null)
{
ada.Update(dt);
}
}
catch (Exception ex)
{
throw ex;
}
finally
{
conn.Close();
}
}
这是一个复制数据库的方法,功能为删除掉原有数据库中的数据,然后根据传过来的DataSet,把DataSet中的数据更新到数据库中。
这只是一个小例子,有不当的地方,希望大家讨论指正。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号