下面是我用来从数据库获取值的代码:
try {
Class.forName("org.apache.derby.jdbc.ClientDriver").newInstance();
connect = DriverManager
.getConnection("jdbc:derby://localhost:1527/TedW;user=x;password=x;");
PreparedStatement statement = connect
.prepareStatement("SELECT * FROM USER");
resultSet = statement.executeQuery();
while (resultSet.next()) {
String user = resultSet.getString("Username");
String password = resultSet.getString("Password");
System.out.println("User: " + user);
System.out.println("ID: " + password);
}
} catch (Exception e) {
System.out.println(e);
}
问题是当我运行它时它显示异常:
java.sql.SQLSyntaxErrorException: Syntax error: Encountered "USER" at line 1, column 15.
我发现表名“USER”存在一些问题。我在创建数据库时看到它是一样的。这是 Derby 中的amde。下面是代码:
CREATE TABLE "USER"
(
"Id" INT not null primary key generated always as identity (START WITH 1, INCREMENT BY 1),
"Username" VARCHAR(20) NOT NULL,
"Password" VARCHAR(20) NOT NULL
);
我哪里可能错了?我错过了什么吗?我可以深入了解一下吗?
谢谢。
最佳答案
USER
是保留关键字,您不能这样命名您的表。检查here .
关于java - java中不寻常的SQL异常,使用derby数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15837602/