1
我在設置新的Hibernate項目時遇到了一個非常基本的問題。JPA/Hibernate映射:「QuerySyntaxException:播放器未映射......」
我有一個實體如下:
@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);
}
但是,當我運行單元測試時,代碼的持久部分似乎工作,但當t他查詢運行我得到以下:這是生活在SRC
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文件/測試/資源/ 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);
那麼找到保存的實體。
有沒有人有什麼問題是什麼問題?我在這方面花了很多時間,找不到解決方案。
,你可以向我們提供您的*** hbm.xml文件中。? –
嘗試將'@ Entity(name =「Player」)'更改爲'@ Entity' – ThomasEdwin
@Fev - 我沒有使用註釋的.hbm.xml文件。 – chrishern