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


来源:http://blog.csdn.net/mutou965175859/article/details/14521925
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值