1

EclipseIndigo、EclipseLink、およびMySQLを使用していますが、conditionというテーブルがあり、その名前で保持する必要がありますが"Query qb = em.createQuery("SELECT c FROM Condition c ")"、eclipseでこのコマンドを実行すると、次の例外がスローされます。

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

1 に答える 1

1

識別子としての予約語は、MySQLで引用符で囲む必要があります。

条件エンティティに以下を追加すると役立ちます(クエリはそのままにしておくことができます):

@Table(name = "`condition`")
于 2012-05-03T19:36:08.383 に答える