gpt4 book ai didi

java - 使用 Java 泛型的 Hibernate 映射异常

转载 作者:行者123 更新时间:2023-11-30 10:51:38 26 4
gpt4 key购买 nike

我正在使用带泛型的 hibernate 来实现某些功能。这里我有两个实体 Country 和 CountryTrans。 CountryTrans 代表 Country 的不同翻译(不同名称)。我正在为这个项目使用 Spring Boot。

我有一个包含 Id 的顶级类。

@MappedSuperclass
public abstract class AbstractEntity {

private Long id;

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
public Long getId() {
return id;
}

public void setId(Long id) {
this.id = id;
}
}

然后是包含翻译类型的 MultiLingualObject 泛型类。

@MappedSuperclass
public abstract class MultiLigualObject<TYPE extends TranslationObject>
extends AbstractEntity {

protected List<TYPE> transInfo = new ArrayList<>();

public abstract List<TYPE> getTransInfo();

public void setTransInfo(List<TYPE> transInfo) {
this.transInfo = transInfo;
}
}

TranslationObject 类表示实体翻译。

@MappedSuperclass
public abstract class TranslationObject extends AbstractEntity {

private String langCode;

@Column(name = "lang_code")
public String getLangCode() {
return langCode;
}

public void setLangCode(String langCode) {
this.langCode = langCode;
}
}

最后是 Country 类..

@Entity
@Table(name = "country")
public class Country extends MultiLigualObject<CountryTrans> {

private String countryCode;
private String alternateCode;

@Column(name = "country_code", nullable = false, length = 2)
public String getCountryCode() {
return this.countryCode;
}

public void setCountryCode(String countryCode) {
this.countryCode = countryCode;
}

@Column(name = "alternate_code", length = 3)
public String getAlternateCode() {
return this.alternateCode;
}

public void setAlternateCode(String alternateCode) {
this.alternateCode = alternateCode;
}

@OneToMany(fetch = FetchType.EAGER, mappedBy = "country")
@Override
public List<CountryTrans> getTransInfo() {
return this.transInfo;
}
}

和 CountryTrans 类。

@Entity
@Table(name = "country_trans")
public class CountryTrans extends TranslationObject {

private String name;

private Country country;

@Column(nullable = false)
public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

@ManyToOne
@JoinColumn(name = "country_id")
public Country getCountry() {
return country;
}

public void setCountry(Country country) {
this.country = country;
}
}

为了测试这个我写了一个简单的测试用例。

    @Test
public void testCountry() throws Exception {
Country country = countryRepository.findByCountryCode("AD");

}

当我运行这个测试用例时,它给出了以下异常。

Caused by: javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.persistenceException(EntityManagerFactoryBuilderImpl.java:1249)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.access$600(EntityManagerFactoryBuilderImpl.java:120)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl$4.perform(EntityManagerFactoryBuilderImpl.java:860)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl$4.perform(EntityManagerFactoryBuilderImpl.java:850)
at org.hibernate.boot.registry.classloading.internal.ClassLoaderServiceImpl.withTccl(ClassLoaderServiceImpl.java:425)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:849)
at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:60)
at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:343)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:318)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1637)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1574)
... 43 more
Caused by: org.hibernate.MappingException: Could not determine type for: java.util.List, at table: country, for columns: [org.hibernate.mapping.Column(trans_info)]
at org.hibernate.mapping.SimpleValue.getType(SimpleValue.java:349)
at org.hibernate.mapping.SimpleValue.isValid(SimpleValue.java:322)
at org.hibernate.mapping.Property.isValid(Property.java:241)
at org.hibernate.mapping.PersistentClass.validate(PersistentClass.java:496)
at org.hibernate.mapping.RootClass.validate(RootClass.java:270)
at org.hibernate.cfg.Configuration.validate(Configuration.java:1360)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1851)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl$4.perform(EntityManagerFactoryBuilderImpl.java:857)
... 51 more

一些基本搜索表明这是字段级访问与属性访问的问题。但在这里,我在属性级别访问中实现了这一点。但不确定为什么会失败。有什么想法吗?

更新

添加 CountryRepository

@Repository
public interface CountryRepository extends JpaRepository<Country, Long> {

Country findByCountryCode(String countryCode);

}

更新 - SQL 脚本

CREATE TABLE country (
id bigint(20) NOT NULL AUTO_INCREMENT,
alternate_code varchar(3) DEFAULT NULL,
country_code varchar(2) NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

CREATE TABLE country_trans (
id bigint(20) NOT NULL AUTO_INCREMENT,
lang_code varchar(255) DEFAULT NULL,
country_id bigint(20) DEFAULT NULL,
name varchar(255) DEFAULT NULL,
PRIMARY KEY (id),
CONSTRAINT FK_COUNTRY_TRAN_ID FOREIGN KEY (country_id) REFERENCES country (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

最佳答案

Hibernate(或 JPA)将使用该类的所有属性,除非您特别用 @Transient 标记它们。它试图找出数据库 transInfo 映射到的列。默认是在Table中查找与参数(transInfo)同名的列,找不到。您可以通过告诉它忽略该参数来解决此问题。

例子:

@Transient
private List<CountryTrans> transInfo;

关于java - 使用 Java 泛型的 Hibernate 映射异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34637671/

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