>  기사  >  데이터 베이스  >  DataSet批量更新数据库

DataSet批量更新数据库

WBOY
WBOY원래의
2016-06-07 15:06:281034검색

业务需要从一个数据库复制数据到另一个数据库。当然可以一条一条的复制,但是两个数据库的表结构相同,通过操作DataSet批量复制数据到另一个数据库,不管从开发效率还是执行效率上来说是不是更好一些呢。 需要注意的点,如下: 1、数据库中必须有主键,这样

     业务需要从一个数据库复制数据到另一个数据库。当然可以一条一条的复制,但是两个数据库的表结构相同,通过操作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中的数据更新到数据库中。

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.