1、使用OleDbDataAdapter根据select语句向其它表中数据更新数据,方法如下:
public static bool DataSetUpdateTable(string selectSql,DataSet ds)
{
try{
OleDbConnertion connection=new OleDbConnection(“链接字符串”);
connection.Open();
DataSet dsNew=new DataSet();
OleDbDataAdapter adapter=new OleDbDataAdapter(" selectSql “,connection);
OleDbCommandBuilder ocb=new OleDbCommandBuilder(adapter);
ocb.QuotePrefix=”[";//此两句是为了排除执行Update命令时提示“insert into语法错误”
ocb.QuoteSuffix="]";
adapter.Fill(dsNew,“ds”);
object[] obj=new object[ ds.Tables[0].Columns.Count];
foreach(DataRow dr in ds.Tables[0] .Rows)
{
dr.ItemArray.CopyTo(obj,0);
daNew.Tables[0].Rows.Add(obj);
}
int count=adapter.Update(dsNew,“ds”);
dsNew.AcceptChanges();
}
catch (System.Data.OleDb.OleDbException ex)
{
//异常处理
return false;
}
return true;
}
2、执行Update 方法时提示“insert into 语法错误”需加上方法中标红的两句话,即
ocb.QuotePrefix="[";
ocb.QuoteSuffix="]";
OleDbDataAdapter 的Update语句执行时提示“insert into语法错误”解决方法
最新推荐文章于 2023-02-20 19:40:21 发布