3

我有一张桌子叫condition. 我需要用那个名字保留它,但是当我执行命令时

Query qb = em.createQuery("SELECT c FROM Condition c ")

我得到这个例外:

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'condition' at line 1
at sun.reflect.GeneratedConstructorAccessor5.newInstance(Unknown Source)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
at com.mysql.jdbc.Util.getInstance(Util.java:386)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1052)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4096)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4028)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2490)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2651)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2683)
at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2144)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:2310)
at org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.executeSelect(DatabaseAccessor.java:931)
at org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.basicExecuteCall(DatabaseAccessor.java:607)

我知道 MySQL 有一个名为 condition 的命令,这就是为什么这个命令会抛出异常。

是否有一种表格可以将我的表命名为条件,这将允许我执行以下命令?

Query qb = em.createQuery("SELECT c FROM Condition c ")
4

2 回答 2

5

这是因为conditionMySQL的保留关键字

试试这个:

Query qb = em.createQuery("SELECT c FROM `Condition` c ")

检查架构对象名称以获取更多详细信息。

我希望它可以帮助你!

于 2013-04-08T14:00:01.893 回答
4

CONDITION是保留关键字。必须使用反引号对其进行转义:

SELECT c FROM `Condition` c

如果您有机会更改标识符,请更改保留关键字列表中不存在的表名。这将避免你未来的头痛。

于 2013-04-08T13:59:05.057 回答