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

来源:互联网 发布:iphone怎么投屏到mac 编辑:程序博客网 时间:2024/06/18 05:06
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
0 0