关于merge

关于DataSet 合并问题,搜了下,也没解决.下面是一个可以合并,而且可以update 的程序.

None.gif        public   DataSet   CreateCmdsAndUpdate(DataSet   myDataSet,string   myConnection,string   mySelectQuery,string   myTableName)     
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            OleDbConnection   myConn   
=   new   OleDbConnection(oleDbConnection2.ConnectionString);   
InBlock.gif            OleDbDataAdapter   myDataAdapter   
=   new   OleDbDataAdapter();   //没数据
InBlock.gif
            myDataAdapter.SelectCommand   =   new   OleDbCommand(mySelectQuery,   myConn);   
InBlock.gif            OleDbCommandBuilder   custCB   
=   new   OleDbCommandBuilder(myDataAdapter);   
InBlock.gif    
InBlock.gif            myConn.Open();   
InBlock.gif            DataSet   custDS   
=   new   DataSet();   
InBlock.gif            myDataAdapter.Fill(custDS,myTableName);
InBlock.gif   
ContractedSubBlock.gifExpandedSubBlockStart.gif            
新增的代码,完成生成一个新的DataSet并和老的merge在一起#region   新增的代码,完成生成一个新的DataSet并和老的merge在一起  
InBlock.gif            DataSet   newData
=new   DataSet(); //新建一个DataSet // 有数据 
InBlock.gif
InBlock.gif             
//创建表   
InBlock.gif
            newData.Tables.Add(myTableName);
InBlock.gif
InBlock.gif            
//拷贝表结构   
ExpandedSubBlockStart.gifContractedSubBlock.gif
            foreach(DataColumn   column   in   custDS.Tables[myTableName].Columns)            dot.gif{   
InBlock.gif                newData.Tables[myTableName].Columns.Add(
new   DataColumn(column.ColumnName.ToString(),column.DataType));   
ExpandedSubBlockEnd.gif            }
              
InBlock.gif        
InBlock.gif            
//设置Primary   Key   
ExpandedSubBlockStart.gifContractedSubBlock.gif
            newData.Tables[myTableName].Rows.Add(new   object[4]dot.gif{0,1,System.DateTime.Now.ToLongTimeString(),11});  
InBlock.gif            
//newData.Tables[myTableName].PrimaryKey=new   DataColumn[1]{newData.Tables[myTableName].Columns["LinkTokenID"]};   
InBlock.gif
InBlock.gif    
InBlock.gif            
InBlock.gif                
//插入新数据  
ExpandedSubBlockStart.gifContractedSubBlock.gif
            custDS.Tables[myTableName].PrimaryKey=new   DataColumn[1]dot.gif{custDS.Tables[myTableName].Columns["LinkTokenID"]};   
InBlock.gif
InBlock.gif            
//custDS.AcceptChanges();
InBlock.gif

InBlock.gif            custDS.Merge(newData); 
//合并两个DataSet  
InBlock.gif
            
InBlock.gif            dataGrid2.SetDataBinding(custDS,myTableName);
InBlock.gif
InBlock.gif
ExpandedSubBlockEnd.gif            
#endregion
   
InBlock.gif    
InBlock.gif            myDataAdapter.Update(custDS,   myTableName);   
InBlock.gif            myConn.Close();   
InBlock.gif            
return   custDS;   
ExpandedBlockEnd.gif        }
 

上述newData 是在程序中创建的,并且填充的数据,一切正常.但是如果将该newData 的数据填充方法换成
OleDataAdapter 从数据库读数据填充,再merge ,则update 执行失败,不能达到预想的效果进行合并.
到底是什么原因呢,请各位高手指点.

转载于:https://www.cnblogs.com/playboy2005/archive/2006/06/11/423392.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值