我正在尝试使用 R 中 RODBC 包的 sqlSave 函数更新 SQL 表。
数据存在于数据框中。
当我尝试运行命令时:
sqlSave(DBConn, dat=df, verbose=T, tablename='table', append=T)
我收到以下错误:
Query: INSERT INTO "table" ( "col1", "col2", "col3", "col4" ) VALUES ( ?,?,?,?,? )
sqlwrite returned
42000 -131 [Sybase][ODBC Driver][Sybase IQ]Syntax error near 'table' on line 1
[RODBC] ERROR: Could not SQLPrepare 'INSERT INTO "table" ( "col1", "col2", "col3", "col4" ) VALUES ( ?,?,?,?,? )'
我在这里做错了什么,导致我无法获取 SQLQuery 中的值?
感谢您提前提供的任何帮助
EDIT 1在@Gordon 评论之后:
错误显示 5 个占位符,但我的 data.frame 只有 4 列。我执行了 dim(df) 并得到了 4。它与 df 的行索引有某种关系吗?
EDIT 2
在执行以下操作时:
sqlSave(DBConn, dat=df, verbose=T, tablename='table', append=T)
现在我得到的错误仍然是相同的,有 4 个占位符,但所有值仍然是(?,?,?,?)
EDIT 3
我也尝试使用 sqlUpdate
sqlUpdate(DBConn, dat=df, verbose=T, tablename='table')
我现在得到的错误是:
Query: UPDATE "table" SET "col2"=?, "col3"=?, "col4"=? WHERE "col1"=?
Error in sqlUpdate(DBConn, t, tablename = "table", verbose = T) :
42000 -131 [Sybase][ODBC Driver][Sybase IQ]Syntax error near 'table' on line 1[RODBC] ERROR: Could not SQLPrepare 'UPDATE "table" SET "col2"=?, "col3"=?, "col4"=? WHERE "col1"=?'