解决此表已属于dataset的方法

本文介绍了一种解决在使用DataSet时向其添加DataTable所遇到的异常的方法。通过创建新的DataTable并复制原始表的数据和结构,然后手动设置表名,可以有效避免错误发生。
//用DataSet.Tables.Add(DataTable)向DataSet中添加table会出现如题的错,为避免此异常,手动为表添加一下名称就可避免,方法如下
        public System.Data.DataTable GetTable(System.Data.DataTable Dt, string tablename)
        {


            Dt.AcceptChanges();


            System.Data.DataTable m_Dt = new System.Data.DataTable();//定义一个新的Table


            int m_RowCount = (int)Dt.Rows.Count;//定义一个变量,值为Dt的行数


            int m_ColCount = Dt.Columns.Count;//定义一个变量,值为Dt的列数


            for (int j = 0; j < m_ColCount; j++)
            {


                m_Dt.Columns.Add(Dt.Columns[j].ColumnName, Dt.Columns[j].DataType);


            }


            for (int i = 0; i < m_RowCount; i++)//增加记录在临时表中
            {


                if (Dt.Rows[i].RowState.ToString() != "Deleted")
                {


                    DataRow NewRow = m_Dt.NewRow();//定义一个新行为m_Dt表的新行


                    for (int j = 0; j < m_ColCount; j++)//循环行
                    {


                        NewRow[j] = Dt.Rows[i][j];


                    }


                    m_Dt.Rows.Add(NewRow);//临时表中增加新行


                }


            }


            m_Dt.TableName = tablename;


            return m_Dt;//返回临时表


        }
在C#中,如果你尝试将一个`DataTable`添加到另一个`DataSet`时,可能会遇到错误:“该表已属于另一个数据集”。这是因为每个`DataTable`只能属于一个`DataSet`。如果需要将一个`DataTable`从一个`DataSet`移动到另一个`DataSet`,必须先将其从原来的`DataSet`移除。 以下是解决这个问题的代码示例: ```csharp using System; using System.Data; class Program { static void Main() { // 创建第一个 DataSetDataTable DataSet originalDataSet = new DataSet(); DataTable table = new DataTable("SampleTable"); table.Columns.Add("ID", typeof(int)); table.Rows.Add(1); originalDataSet.Tables.Add(table); // 创建第二个 DataSet DataSet newDataSet = new DataSet(); // 将 DataTable 从原 DataSet 中移除并添加到新 DataSet if (table.DataSet != null) { table.DataSet.Tables.Remove(table); // 从原始 DataSet 中移除 } newDataSet.Tables.Add(table); // 添加到新的 DataSet Console.WriteLine("Table moved successfully."); } } ``` ### 解释: 上述代码展示了如何正确地将一个`DataTable`从一个`DataSet`移动到另一个`DataSet`。具体步骤如下: 1. 检查`DataTable`是否已经属于某个`DataSet`。 2. 如果属于某个`DataSet`,则通过调用`Tables.Remove(table)`方法将其从当前`DataSet`中移除。 3. 最后,将`DataTable`添加到目标`DataSet`中。 这样可以避免“该表已属于另一个数据集”的错误。 ### 注意事项: - 如果你需要保留原始`DataSet`中的`DataTable`副本,则可以通过克隆或复制的方式创建一个新的`DataTable`实例。 - 使用`Clone()`方法可以复制结构(列定义等),但不复制数据。 - 使用`Copy()`方法可以复制结构和数据。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值