UCanAccess SQL 插入失败;查询在 MS Access 意外令牌中工作正常 (UcanaccessStatement.java:222)
UCanAccess SQL Insert failing; query works fine in MS Access unexpected token (UcanaccessStatement.java:222)
这是我第一次尝试在 Java 中构建一些东西,这里的最终目标是简单地将 excel 文件导入 MS Access 数据库。
我怀疑存在某种数据不兼容错误,或者 UCA 正在做一些清理查询的事情,但我对 Java 或 UCanAccess 的了解还不足以追踪它。
这是我组装的查询,运行可以直接在 MS Access 中插入数据:
INSERT INTO XXXX_XA_Data_1 ([Date],[Fund Ticker],[Unique ID],[Cash & Cash Equiv],[Mkt Value of Security Holdings],[Today's Future Variation Margin],[Other Net Assets],[Total Net Assets],[Fund Shares],[NAV],[Fund Sales ($)],[Fund Sales (Shares)],[Fund Redemptions ($)],[Fund Redemptions (Shares)])
VALUES (#12/01/2001#,"XXXXX","00000000-XXXXX",0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000);
一些数据已替换为 X 和 0,但所有列名都相同。
我已经尝试了几种变体,看看哪些会起作用,我可以让它插入基金代码、唯一 ID 和现金及现金等价物。基于这些尝试,我认为日期格式或某些列名称正在破坏它,但我找不到其他遇到过这个确切问题的人。
这是 java:
Class.forName("net.ucanaccess.jdbc.UcanaccessDriver");
db = DriverManager.getConnection("jdbc:ucanaccess://C:" + path_db);
...
Statement s = db.createStatement();
try {
int result = s.executeUpdate(rowquery);
} catch (Exception e) {
e.printStackTrace();
}
完整跟踪:
[2016-02-18 13:37:29.053]: SQL Insert failed for item 1. Aborting with exception: net.ucanaccess.jdbc.UcanaccessSQLException: UCAExc:::3.0.3.1 unexpected token: [
at net.ucanaccess.jdbc.UcanaccessStatement.executeUpdate(UcanaccessStatement.java:222)
at DailyImporter.main(DailyImporter.java:226)
Caused by: java.sql.SQLSyntaxErrorException: unexpected token: [
at org.hsqldb.jdbc.JDBCUtil.sqlException(Unknown Source)
at org.hsqldb.jdbc.JDBCUtil.sqlException(Unknown Source)
at org.hsqldb.jdbc.JDBCStatement.fetchResult(Unknown Source)
at org.hsqldb.jdbc.JDBCStatement.executeUpdate(Unknown Source)
at net.ucanaccess.jdbc.ExecuteUpdate.executeWrapped(ExecuteUpdate.java:67)
at net.ucanaccess.jdbc.AbstractExecute.executeBase(AbstractExecute.java:152)
at net.ucanaccess.jdbc.ExecuteUpdate.execute(ExecuteUpdate.java:50)
at net.ucanaccess.jdbc.UcanaccessStatement.executeUpdate(UcanaccessStatement.java:220)
... 1 more
Caused by: org.hsqldb.HsqlException: unexpected token: [
at org.hsqldb.error.Error.parseError(Unknown Source)
at org.hsqldb.ParserBase.unexpectedToken(Unknown Source)
at org.hsqldb.ParserBase.checkIsIdentifier(Unknown Source)
at org.hsqldb.ParserDQL.readSimpleColumnName(Unknown Source)
at org.hsqldb.ParserDQL.readSimpleColumnNames(Unknown Source)
at org.hsqldb.ParserDML.compileInsertStatement(Unknown Source)
at org.hsqldb.ParserCommand.compilePart(Unknown Source)
at org.hsqldb.ParserCommand.compileStatements(Unknown Source)
at org.hsqldb.Session.executeDirectStatement(Unknown Source)
at org.hsqldb.Session.execute(Unknown Source)
... 7 more
这里是否有需要解决的列名或其他数据格式问题?或者 UCanAccess 以外的库可以简单地 运行 SELECT/INSERT 查询 MS Access 数据库?
UCanAccess 目前难以解析字段名称包含撇号(a.k.a。"single quote" 字符)'
的 SQL 语句,例如,
sql = "INSERT INTO XXXX_XA_Data_1 ([Today's Future Variation Margin]) VALUES (1)";
该问题已报告给 UCanAccess 开发团队,预计将在 UCanAccess 的未来版本中修复。
同时,如果您不需要执行任何复杂的 SQL 查询,那么您可以 import com.healthmarketscience.jackcess.*;
并直接使用 Jackcess API。例如,要执行与上面的 INSERT 语句等效的操作,您可以执行
String dbFileSpec = "C:/Users/Public/example.accdb";
try (Database db = DatabaseBuilder.open(new File(dbFileSpec))) {
Table tbl = db.getTable("XXXX_XA_Data_1");
HashMap rowData = new HashMap();
rowData.put("Today's Future Variation Margin", 1);
tbl.addRowFromMap(rowData);
}
这是我第一次尝试在 Java 中构建一些东西,这里的最终目标是简单地将 excel 文件导入 MS Access 数据库。
我怀疑存在某种数据不兼容错误,或者 UCA 正在做一些清理查询的事情,但我对 Java 或 UCanAccess 的了解还不足以追踪它。
这是我组装的查询,运行可以直接在 MS Access 中插入数据:
INSERT INTO XXXX_XA_Data_1 ([Date],[Fund Ticker],[Unique ID],[Cash & Cash Equiv],[Mkt Value of Security Holdings],[Today's Future Variation Margin],[Other Net Assets],[Total Net Assets],[Fund Shares],[NAV],[Fund Sales ($)],[Fund Sales (Shares)],[Fund Redemptions ($)],[Fund Redemptions (Shares)])
VALUES (#12/01/2001#,"XXXXX","00000000-XXXXX",0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000,0.0000);
一些数据已替换为 X 和 0,但所有列名都相同。
我已经尝试了几种变体,看看哪些会起作用,我可以让它插入基金代码、唯一 ID 和现金及现金等价物。基于这些尝试,我认为日期格式或某些列名称正在破坏它,但我找不到其他遇到过这个确切问题的人。
这是 java:
Class.forName("net.ucanaccess.jdbc.UcanaccessDriver");
db = DriverManager.getConnection("jdbc:ucanaccess://C:" + path_db);
...
Statement s = db.createStatement();
try {
int result = s.executeUpdate(rowquery);
} catch (Exception e) {
e.printStackTrace();
}
完整跟踪:
[2016-02-18 13:37:29.053]: SQL Insert failed for item 1. Aborting with exception: net.ucanaccess.jdbc.UcanaccessSQLException: UCAExc:::3.0.3.1 unexpected token: [
at net.ucanaccess.jdbc.UcanaccessStatement.executeUpdate(UcanaccessStatement.java:222)
at DailyImporter.main(DailyImporter.java:226)
Caused by: java.sql.SQLSyntaxErrorException: unexpected token: [
at org.hsqldb.jdbc.JDBCUtil.sqlException(Unknown Source)
at org.hsqldb.jdbc.JDBCUtil.sqlException(Unknown Source)
at org.hsqldb.jdbc.JDBCStatement.fetchResult(Unknown Source)
at org.hsqldb.jdbc.JDBCStatement.executeUpdate(Unknown Source)
at net.ucanaccess.jdbc.ExecuteUpdate.executeWrapped(ExecuteUpdate.java:67)
at net.ucanaccess.jdbc.AbstractExecute.executeBase(AbstractExecute.java:152)
at net.ucanaccess.jdbc.ExecuteUpdate.execute(ExecuteUpdate.java:50)
at net.ucanaccess.jdbc.UcanaccessStatement.executeUpdate(UcanaccessStatement.java:220)
... 1 more
Caused by: org.hsqldb.HsqlException: unexpected token: [
at org.hsqldb.error.Error.parseError(Unknown Source)
at org.hsqldb.ParserBase.unexpectedToken(Unknown Source)
at org.hsqldb.ParserBase.checkIsIdentifier(Unknown Source)
at org.hsqldb.ParserDQL.readSimpleColumnName(Unknown Source)
at org.hsqldb.ParserDQL.readSimpleColumnNames(Unknown Source)
at org.hsqldb.ParserDML.compileInsertStatement(Unknown Source)
at org.hsqldb.ParserCommand.compilePart(Unknown Source)
at org.hsqldb.ParserCommand.compileStatements(Unknown Source)
at org.hsqldb.Session.executeDirectStatement(Unknown Source)
at org.hsqldb.Session.execute(Unknown Source)
... 7 more
这里是否有需要解决的列名或其他数据格式问题?或者 UCanAccess 以外的库可以简单地 运行 SELECT/INSERT 查询 MS Access 数据库?
UCanAccess 目前难以解析字段名称包含撇号(a.k.a。"single quote" 字符)'
的 SQL 语句,例如,
sql = "INSERT INTO XXXX_XA_Data_1 ([Today's Future Variation Margin]) VALUES (1)";
该问题已报告给 UCanAccess 开发团队,预计将在 UCanAccess 的未来版本中修复。
同时,如果您不需要执行任何复杂的 SQL 查询,那么您可以 import com.healthmarketscience.jackcess.*;
并直接使用 Jackcess API。例如,要执行与上面的 INSERT 语句等效的操作,您可以执行
String dbFileSpec = "C:/Users/Public/example.accdb";
try (Database db = DatabaseBuilder.open(new File(dbFileSpec))) {
Table tbl = db.getTable("XXXX_XA_Data_1");
HashMap rowData = new HashMap();
rowData.put("Today's Future Variation Margin", 1);
tbl.addRowFromMap(rowData);
}