OleDbDataAdapter 的Update语句执行时提示“insert into语法错误”解决方法

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="]";

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值