• DataSet批量更新数据库


         业务需要从一个数据库复制数据到另一个数据库。当然可以一条一条的复制,但是两个数据库的表结构相同,通过操作DataSet批量复制数据到另一个数据库,不管从开发效率还是执行效率上来说是不是更好一些呢。

        需要注意的点,如下:

    1、数据库中必须有主键,这样才便于增删改查;

    2、SqlDataAdapter必须放在SqlCommandBuilder中,以用于批量执行DataSet中的修改;

    3、修改后的DataSet需执行AcceptChanges()方法后,才能更新DataSet,以便于下一步操作;

    4、SqlDataAdapter执行Update的数据库不一定是Fill的数据库,只要表结构相同即可。

    示例代码如下:

            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中的数据更新到数据库中。

    这只是一个小例子,有不当的地方,希望大家讨论指正。

  • 相关阅读:
    Unity 3D 一个简单的角色控制脚本
    Unity3D 纹理偏移(TextureOffset)浅析
    递归函数的原理
    彻底搞定 C/C++ 指针
    zygote的分裂
    SystemServer分析
    Zygote原理学习
    Vmware Linux虚拟机磁盘扩容方法
    Ubuntu12.04 64bit版本下载Android源码完整教程
    Android2.2源码属性服务分析
  • 原文地址:https://www.cnblogs.com/sshoub/p/2364404.html
Copyright © 2020-2023  润新知