编译查询时出错:抽象模式类型"实体"未知

Moh*_*ine 15 java persistence jpa jpql

我正在开发一个带有数据库连接的游戏,我使用JPA来保存我的数据.这是我的游戏实体:

@Entity
@Table(name = "game")
public class Game implements Serializable {
private static final long serialVersionUID = 1L;

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "game_id")
private int id;

@Column(name = "name")
private String name;

@Column(name = "nbTurns")
private int nbTurns;

@Column(name = "playedOn")
@Temporal(TemporalType.TIMESTAMP)
private Date playedOn;

@ElementCollection(fetch = FetchType.EAGER)
@CollectionTable(name = "game_humans", joinColumns = @JoinColumn(name = "game_id"))
@MapKeyColumn(name = "human_id")
@Column(name = "isDead")
private Map<Human, Boolean> humans;
Run Code Online (Sandbox Code Playgroud)

这是我的人类实体:

@Entity
@Table(name = "human")
public class Human implements Serializable {

private static final long serialVersionUID = 1L;

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int id;
@Column(name = "name")
private String name;
@OneToOne
private Building building;
Run Code Online (Sandbox Code Playgroud)

为了获得存储在数据库中的所有人的列表,我使用这个DAO,它工作得非常好并且还获得了Building实体:

public class HumanDAO implements DAO<Human> {

// ...
public List<Human> getAllHumans() {
    TypedQuery<Human> query = em.createQuery("SELECT h FROM human h ORDER BY h.name", Human.class);
    return query.getResultList();
}
Run Code Online (Sandbox Code Playgroud)

问题是当我尝试使用JPQL查询SELECT g FROM game g获取所有游戏的列表时,我收到此错误:

[EL Info]: 2013-11-25 13:40:27.761--ServerSession(1943119327)--EclipseLink, version: Eclipse Persistence Services - 2.5.0.v20130507-3faac2b
[EL Info]: connection: 2013-11-25 13:40:28.151--ServerSession(1943119327)--file:/Users/amine/Documents/workspace/ZombiesServer/target/classes/_ZombiesServer login successful
[WARNING] 
java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:297)
    at java.lang.Thread.run(Thread.java:724)
Caused by: java.lang.IllegalArgumentException: An exception occurred while creating a query in EntityManager: 
Exception Description: Problem compiling [SELECT g FROM game g]. 
[14, 18] The abstract schema type 'game' is unknown.
    at org.eclipse.persistence.internal.jpa.EntityManagerImpl.createQuery(EntityManagerImpl.java:1585)
    at org.eclipse.persistence.internal.jpa.EntityManagerImpl.createQuery(EntityManagerImpl.java:1605)
    at com.amine.zombies.DAO.GameDAO.getAllGames(GameDAO.java:80)
    at com.amine.zombies.application.Application.main(Application.java:21)
    ... 6 more
Run Code Online (Sandbox Code Playgroud)

And*_*i I 24

你应该有

SELECT g FROM Game g//you have game
Run Code Online (Sandbox Code Playgroud)

但你有game而不是Game.

@Table注释用于DB.

如果您需要更改您的名称,请JPQL使用@Entity注释: @Entity(name="nameUsedInJPQL") => nameUsedInJPQL is used in your JPQL.

如果您未在其中指定任何内容,@Entity则使用区分大小写的Entity类名称.

  • 通过回答您的问题更改了答案. (2认同)

leo*_*rer 14

在我的情况下,我忘了在persistence.xml中注册它.

  • @PauloFreitas,我来到这里寻找这个问题的标题.也许这个答案对其他人有用.就我而言,这是解决方案. (9认同)
  • @PauloFreitas,没有关系?我有这种错误"抽象模式类型'实体'是未知的",问题是我忘了在persistence.xml中声明表.对我来说这是解决方案.很抱歉用这个解决方案解决了我的错误. (4认同)

小智 5

我刚刚遇到了同样的情况,但我的 JPQL 查询是正确的!它出现在 Glassfish 4.1(版本 13)(使用 EclipseLink)中。

经过几次谷歌搜索和一些代码注释后,我发现“抽象模式类型‘MyEntity’未知”的根本原因是在实体类中使用了 Java 8 lambda 代码

GF 附带的 EclipseLink 版本似乎(尚)不支持 Java 8 的任何功能。更多信息,请参阅相关错误报告。

希望这可以帮助。


小智 5

类名应该是查询中的表名,而不是 SELECT g FROM Game g