在我的玩家实体中,我试图使用公式来包含所有玩家的得分总和。
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import org.hibernate.annotations.Formula;
import com.google.gwt.user.client.rpc.IsSerializable;
@Entity
public class Player implements IsSerializable {
@Id
private String name;
@Column(nullable = false)
private Integer score;
@Formula(value = " SELECT sum(score) ")
private Integer totalScore = 0;
[...]
}
但是,我在加载播放器时收到了语法错误。
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
'SELECT sum(this_.score) as formula0_0_ from Player this_' at line 1
奇怪的是,这个查询看起来完全有效,当我在与hibernate相同的数据库上运行它时,我得到了预期的结果。
SELECT sum(this_.score) as formula0_0_ from Player this_
1 row(s) returned
我已将hibernate设置为使用mysql方言
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
为什么jdbc会为正确的查询抛出错误?
答案 0 :(得分:1)
似乎
@Formula(value = " SELECT sum(score) ")
应该是
@Formula(value = " sum(score) ")
代替。有可能(我还没试过)发送给MySQL的SQL查询是
SELECT SELECT sum(this_.score) as formula0_0_ from Player this_
显然无效。
MySQL仅显示从遇到错误的点开始的SQL字符串。在您的情况下,这是无益的,因为从这一点开始,您有一个有效的SQL查询。