gpt4 book ai didi

java - JPA/Hibernate 映射 : “QuerySyntaxException: Player is not mapped…”

转载 作者:行者123 更新时间:2023-11-30 03:48:34 25 4
gpt4 key购买 nike

我在设置新的 Hibernate 项目时遇到了一个非常基本的问题。

我有一个实体,如下所示:

@Entity(name = "Player")
public class PlayerEntity implements Serializable {

private static final long serialVersionUID = 6584040856373261900L;

@Id
private long id;

@Column
private String forename;

@Column
private String surname;

@Column
private String team;

@Column
@Enumerated(EnumType.STRING)
private Position position;

@Column
private boolean selected;

@Column
private int totalPoints;

public PlayerEntity() {
}

public PlayerEntity(final long id, final String forename, final String surname, final String team,
final Position position, final boolean selected, final int totalPoints) {
this.id = id;
this.forename = forename;
this.surname = surname;
this.team = team;
this.position = position;
this.selected = selected;
this.totalPoints = totalPoints;
}

/**
* @return the id
*/
public long getId() {
return id;
}

/**
* @param id the id to set
*/
public void setId(long id) {
this.id = id;
}

/**
* @return the forename
*/
public String getForename() {
return forename;
}

/**
* @param forename the forename to set
*/
public void setForename(String forename) {
this.forename = forename;
}

/**
* @return the surname
*/
public String getSurname() {
return surname;
}

/**
* @param surname the surname to set
*/
public void setSurname(String surname) {
this.surname = surname;
}

/**
* @return the team
*/
public String getTeam() {
return team;
}

/**
* @param team the team to set
*/
public void setTeam(String team) {
this.team = team;
}

/**
* @return the position
*/
public Position getPosition() {
return position;
}

/**
* @param position the position to set
*/
public void setPosition(Position position) {
this.position = position;
}

/**
* @return the selected
*/
public boolean isSelected() {
return selected;
}

/**
* @param selected the selected to set
*/
public void setSelected(boolean selected) {
this.selected = selected;
}

/**
* @return the totalPoints
*/
public int getTotalPoints() {
return totalPoints;
}

/**
* @param totalPoints the totalPoints to set
*/
public void setTotalPoints(int totalPoints) {
this.totalPoints = totalPoints;
}

以及按如下方式访问数据的数据服务:

public class PlayerDataServiceJpa implements PlayerDataService {

@PersistenceContext
private EntityManager entityManager;

public void addPlayers(final List<Player> players) {
for (final Player domainPlayer : players) {
final PlayerEntity entityPlayer = new PlayerEntity();

BeanUtils.copyProperties(domainPlayer, entityPlayer);

entityManager.persist(entityPlayer);
}
}

public List<Player> getPlayers() {
final List<Player> domainPlayers = new ArrayList<Player>();

final List<PlayerEntity> entityPlayers = entityManager.createQuery("SELECT tc FROM PlayerEntity tc", PlayerEntity.class).getResultList();

for (final PlayerEntity entityPlayer : entityPlayers) {
final Player domainPlayer = new Player();

BeanUtils.copyProperties(entityPlayer, domainPlayer);

domainPlayers.add(domainPlayer);
}

return domainPlayers;
}

然后我尝试按如下方式对数据服务进行单元测试:

@Transactional      
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(value = {"/hsqlDatasourceContext.xml", "/testApplicationContext.xml"})
public class PlayerDataServiceJpaTest {

@PersistenceContext
private EntityManager entityManager;

@Autowired
@Qualifier(value = "playerDataServiceJpa")
private PlayerDataServiceJpa playerDataServiceJpa;

@Test
public void testGetPlayers() {
// arrange
final PlayerEntity player = TestDataUtil.createEntityPlayer(1);
entityManager.persist(player);

PlayerEntity find = entityManager.find(PlayerEntity.class, TestDataUtil.PLAYER_1_ID);
assertThat(find).isNotNull();
assertThat(find.getForename()).isEqualTo(TestDataUtil.PLAYER_1_FORENAME);

// act
final List<Player> players = playerDataServiceJpa.getPlayers();

// assert
assertThat(players).hasSize(1);

final Player retrievedPlayer = players.get(0);
assertThat(retrievedPlayer.getId()).isEqualTo(TestDataUtil.PLAYER_1_ID);
assertThat(retrievedPlayer.getForename()).isEqualTo(TestDataUtil.PLAYER_1_FORENAME);
assertThat(retrievedPlayer.getSurname()).isEqualTo(TestDataUtil.PLAYER_1_SURNAME);
assertThat(retrievedPlayer.getTeam()).isEqualTo(TestDataUtil.TEST_TEAM);
assertThat(retrievedPlayer.getTotalPoints()).isEqualTo(TestDataUtil.PLAYER_1_POINTS);
}

@Test
public void testAddPlayers() {
// arrange
final Player player1 = TestDataUtil.createModelPlayer(1);
final Player player2 = TestDataUtil.createModelPlayer(2);

// act
playerDataServiceJpa.addPlayers(Arrays.asList(player1, player2));

// assert
final List<Player> players = playerDataServiceJpa.getPlayers();

assertThat(players).hasSize(2);

final Player retrievedPlayer = players.get(0);
assertThat(retrievedPlayer.getId()).isEqualTo(TestDataUtil.PLAYER_1_ID);
assertThat(retrievedPlayer.getForename()).isEqualTo(TestDataUtil.PLAYER_1_FORENAME);
assertThat(retrievedPlayer.getSurname()).isEqualTo(TestDataUtil.PLAYER_1_SURNAME);
assertThat(retrievedPlayer.getTeam()).isEqualTo(TestDataUtil.TEST_TEAM);
assertThat(retrievedPlayer.getTotalPoints()).isEqualTo(TestDataUtil.PLAYER_1_POINTS);
}

但是,当我运行单元测试时,代码的持久部分似乎可以工作,但是当查询运行时,我得到以下结果:

org.hibernate.hql.internal.ast.QuerySyntaxException: PlayerEntity is not mapped
at org.hibernate.hql.internal.ast.util.SessionFactoryHelper.requireClassPersister(SessionFactoryHelper.java:189)
at org.hibernate.hql.internal.ast.tree.FromElementFactory.addFromElement(FromElementFactory.java:109)

我的 persistence.xml 文件位于 src/test/resources/META-INF 中

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
<persistence-unit name="jpaData" transaction-type="RESOURCE_LOCAL">

<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>aaa.bbb.ccc.entity.PlayerEntity</class>

</persistence-unit>
</persistence>

hsqlDatasourceContext.xml 文件看起来像

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context"
xmlns:jee="http://www.springframework.org/schema/jee" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jaxrs="http://cxf.apache.org/jaxrs" xmlns:cxf="http://cxf.apache.org/core"
xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd http://cxf.apache.org/jaxrs http://cxf.apache.org/schemas/jaxrs.xsd http://cxf.apache.org/core http://cxf.apache.org/schemas/core.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"
xmlns:jdbc="http://www.springframework.org/schema/jdbc">

<!-- HSQLDB datasource -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="org.hsqldb.jdbcDriver" />
<property name="url" value="jdbc:hsqldb:mem:ex;sql.syntax_mys=true" />
<property name="username" value="sa" />
<property name="password" value="" />
</bean>

<bean id="jpaProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
<property name="properties">
<props>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitName" value="jpaData" />
<property name="dataSource" ref="dataSource" />
<property name="jpaProperties" ref="jpaProperties" />
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>

<bean id="persistenceProvider" class="org.hibernate.ejb.HibernatePersistence" />
</beans>

这个问题看起来与以下问题非常相似JPA mapping: "QuerySyntaxException: foobar is not mapped..."但我的 SELECT 语句中的大小写是正确的。

有趣的是,如果我执行 entityManager.find(PlayerEntity.class, 1l); 则会找到保存的实体。

有人知道问题出在哪里吗?我花了很长时间在这个问题上,但找不到解决方案。

最佳答案

Doh - 男生代表我犯了错误......

@Entity(name = "Player")

应该是......

@Entity
@Table(name = "Player")

关于java - JPA/Hibernate 映射 : “QuerySyntaxException: Player is not mapped…” ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24971854/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com