复制DataTable的一种方法

      如果将程序返回的DataTable加入到自己定义的一个DataSet中,直接用ds.Tables.Add(dt)的方法,就会出现“该DataTable已属于另外一个DataSet”的错误。这时候我们需要建一个新的DataTable,并将原来的DataTable的结构及数据导入到新的DataTable中,这时候就可以使用下面的方法(当然方法并不是唯一的):


ExpandedBlockStart.gif ContractedBlock.gif /**/ /// <summary>
InBlock.gif        
/// 复制DataTable
InBlock.gif        
/// </summary>
InBlock.gif        
/// <param name="copyDt">数据源</param>
InBlock.gif        
/// <param name="tableName">新DataTable名称</param>
ExpandedBlockEnd.gif        
/// <returns>复制后的DataTable</returns>

None.gif          private  DataTable CopyDataTable(DataTable copyDt,  string  tableName)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            DataTable dt 
= new DataTable(tableName);
InBlock.gif            
foreach (DataColumn columm in copyDt.Columns)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                dt.Columns.Add(columm.ColumnName,columm.DataType);
ExpandedSubBlockEnd.gif            }

InBlock.gif
InBlock.gif            
foreach (DataRow row in copyDt.Rows)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                dt.BeginInit();
InBlock.gif                dt.ImportRow(row);
InBlock.gif                dt.EndInit();
ExpandedSubBlockEnd.gif            }

InBlock.gif
InBlock.gif            
return dt;
ExpandedBlockEnd.gif        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值