gpt4 book ai didi

java.sql.SQLSyntaxErrorException : user lacks privilege or object not found: YEAR

转载 作者:行者123 更新时间:2023-12-02 10:55:57 25 4
gpt4 key购买 nike

我正在尝试使用 SQL 从 Java 代码编写一个查询,以查找两个日期列之间的年份差异。我有一个表 tblExportHTC,其中包含 VisitDateDateOfBirth 列,我想计算两列之间的年数。

我的java代码块:

 try {
String path = selectedFiles;
Connection conn = DriverManager.getConnection("jdbc:ucanaccess://" + path + ";jackcessOpener=app.test.CryptCodecOpener", "", "");
Statement s = conn.createStatement();
ResultSet rs = s.executeQuery("SELECT DATEDIFF(year,vis.VisitDate,vis.DateOfBirth) as date_diff "
+ " FROM tblExportHTC vis WHERE vis.ClientCode='PITC-TENT-4-093'");
while (rs.next()) {
int visits_count = rs.getInt("date_diff");
System.err.println("index_pos_from_sexual_partners: " + visits_count);
}
} catch (SQLException ex) {
ex.printStackTrace();
}

每当我尝试运行代码时,都会收到错误

Caused by: java.sql.SQLSyntaxErrorException: user lacks privilege or object not found: YEAR
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.executeQuery(Unknown Source)
at net.ucanaccess.jdbc.UcanaccessStatement.executeQuery(UcanaccessStatement.java:216)
Caused by: org.hsqldb.HsqlException: user lacks privilege or object not found: YEAR
at org.hsqldb.error.Error.error(Unknown Source)
at org.hsqldb.error.Error.error(Unknown Source)
at org.hsqldb.ExpressionColumn.checkColumnsResolved(Unknown Source)
at org.hsqldb.QueryExpression.resolve(Unknown Source)
at org.hsqldb.ParserDQL.compileCursorSpecification(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)

我想要的是获取列 VisitDateDateOfBirth 之间的年数。

最佳答案

我找到了答案:我必须使用 TIMESTAMPDIFF() 函数而不是 DATEDIFF() 并且它似乎工作得很好。

try {
String path = selectedFiles;
Connection conn = DriverManager.getConnection("jdbc:ucanaccess://" + path + ";jackcessOpener=app.test.CryptCodecOpener", "", "");
Statement s = conn.createStatement();
ResultSet rs = s.executeQuery("SELECT TIMESTAMPDIFF(year,vis.VisitDate,vis.DateOfBirth) as date_diff "
+ " FROM tblExportHTC vis WHERE vis.ClientCode='PITC-TENT-4-093'");
while (rs.next()) {
int visits_count = rs.getInt("date_diff");
System.err.println("index_pos_from_sexual_partners: " + visits_count);
}
} catch (SQLException ex) {
ex.printStackTrace();
}

关于java.sql.SQLSyntaxErrorException : user lacks privilege or object not found: YEAR,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51746071/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com