尝试从数据库中列出带有简单约束的hibernate条件时出现错误
Criteria criteria = session.createCriteria(Licence.class);
criteria.add(Restrictions.eq("gym", gym.getId()));
List<Licence> list = criteria.list();
我有两个类:Licence
与关联Gym
。这两个类正在扩展DataModel
,用于管理有关数据版本的信息-(创建和分配,谁和何时)。这两个类具有的重要意义@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
。
执照
@Entity
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
public class Licence extends DataModel implements Serializable {
private Gym gym;
private String licenceType;
private String keyCode;
private Date expireDate;
private ELicenceExpiry expired;
public Licence() {
}
@ManyToOne
@JoinColumn(name="gym_id")
public Gym getGym() {
return gym;
}
public void setGym(Gym gym) {
this.gym = gym;
}
@Column(name = "licence_type")
public String getLicenceType() {
return licenceType;
}
public void setLicenceType(String licenceType) {
this.licenceType = licenceType;
}
@Column(name = "key_code")
public String getKeyCode() {
return keyCode;
}
public void setKeyCode(String keyCode) {
this.keyCode = keyCode;
}
@Column(name = "expire_date")
public Date getExpireDate() {
return expireDate;
}
public void setExpireDate(Date expireDate) {
this.expireDate = expireDate;
}
@Column(name = "expired")
@Enumerated(EnumType.ORDINAL)
public ELicenceExpiry getExpired() {
return expired;
}
public void setExpired(ELicenceExpiry expired) {
this.expired = expired;
}
}
健身房
@Entity
@Inheritance(strategy= InheritanceType.SINGLE_TABLE)
public class Gym extends DataModel implements Serializable{
private String shortName;
private String name;
private String nip;
private String street;
private String postCode;
private String localization;
private String telephone;
public Gym(){};
@Column(name="short_name")
public String getShortName() {
return shortName;
}
public void setShortName(String shortName) {
this.shortName = shortName;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getNip() {
return nip;
}
public void setNip(String nip) {
this.nip = nip;
}
public String getStreet() {
return street;
}
public void setStreet(String street) {
this.street = street;
}
@Column(name="post_code")
public String getPostCode() {
return postCode;
}
public void setPostCode(String postCode) {
this.postCode = postCode;
}
public String getLocalization() {
return localization;
}
public void setLocalization(String localization) {
this.localization = localization;
}
public String getTelephone() {
return telephone;
}
public void setTelephone(String telephone) {
this.telephone = telephone;
}
}
数据模型
@MappedSuperclass
public abstract class DataModel implements Serializable{
protected Long id;
protected String editor;
protected Date editDate;
protected Time editTime;
protected int dataState;
@Id
@GeneratedValue
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getEditor() {
return editor;
}
public void setEditor(String editor) {
this.editor = editor;
}
@Column(name="edit_date")
public Date getEditDate() {
return editDate;
}
public void setEditDate(Date editDate) {
this.editDate = editDate;
}
@Column(name="edit_time")
public Time getEditTime() {
return editTime;
}
public void setEditTime(Time editTime) {
this.editTime = editTime;
}
@Column(name="data_state")
public int getDataState() {
return dataState;
}
public void setDataState(int dataState) {
this.dataState = dataState;
}
}
的MySQL
CREATE TABLE licence(
id INT(5) NOT NULL AUTO_INCREMENT,
gym_id int(3),
licence_type VARCHAR(10),
key_code VARCHAR(10),
expire_date DATE,
expired INT(1),
editor VARCHAR(10),
edit_date DATE,
edit_time TIME,
data_state INT(1) NOT NULL,
PRIMARY KEY (id),
FOREIGN KEY (gym_id) REFERENCES gym(id) ON DELETE SET NULL
);
CREATE TABLE gym(
id INT(3) NOT NULL AUTO_INCREMENT,
short_name VARCHAR(16) NOT NULL UNIQUE,
name VARCHAR(100) NOT NULL,
street VARCHAR(100),
post_code VARCHAR(6),
localization VARCHAR(64),
nip VARCHAR(13),
telephone VARCHAR(15),
editor VARCHAR(10),
edit_date DATE,
edit_time TIME,
data_state INT(1) NOT NULL,
PRIMARY KEY (id)
);
例外:
org.hibernate.PropertyAccessException: IllegalArgumentException occurred calling getter of pl.fitpartner.model.DataModel.id
at org.hibernate.property.BasicPropertyAccessor$BasicGetter.get(BasicPropertyAccessor.java:192)
at org.hibernate.tuple.entity.AbstractEntityTuplizer.getIdentifier(AbstractEntityTuplizer.java:346)
at org.hibernate.persister.entity.AbstractEntityPersister.getIdentifier(AbstractEntityPersister.java:4746)
at org.hibernate.persister.entity.AbstractEntityPersister.isTransient(AbstractEntityPersister.java:4465)
(...)
Caused by: java.lang.IllegalArgumentException: java.lang.ClassCastException@37bd68c3
at sun.reflect.GeneratedMethodAccessor2.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:483)
at org.hibernate.property.BasicPropertyAccessor$BasicGetter.get(BasicPropertyAccessor.java:169)
... 28 more
我做错了什么?
问题内容: 好的,这可能是一个远景,但这是可行的。 在Java(JRE 1.6.0_26-b03)中,我有两个类及其子类。它们都需要是持久性对象,而我正在使用Hibernate Annotations来实现此目的。我大约有210个可以正确持久保存的类。除了一个不是。 我的问题是,除了以外,我拒绝以任何方式继承。当我说“拒绝”时,我的意思是 整个JRE崩溃 。 这有点问题,因为我真的很想成为的映射超
主要内容:连接策略示例在连接策略中,为每个实体类生成一个单独的表。 每个表的属性都与主键连接。 它消除了字段字重复的可能性。 以下语法表示连接的策略: - 连接策略示例 在这个例子中,我们将员工分为活跃员工和退休员工。 因此,子类和继承父类的和字段。 现在,按照以下步骤创建JPA项目 - 第1步: 在包下创建一个根实体类并指定所有必需的属性和注释。 文件:Employee.java - 第2步: 在包下创建实体类(它是
主要内容:单表策略示例单表策略是定义继承实现的最简单有效的方法之一。 在这种方法中,多个实体类的实例仅作为属性存储在单个表中。 以下语法表示单个表策略 - 单表策略示例 在这个例子中,我们将员工分为活跃员工和退休员工。 因此,子类和继承父类的和字段。 现在,按照以下步骤创建JPA项目 - 第1步: 在包下创建一个根实体类并指定所有必需的属性和注释。 文件:Employee.java - 第2步: 在包下创建实体类(它是
主要内容:连接策略示例在按类表策略中,为每个子实体类生成一个单独的表。 与连接策略不同,在按类表策略中不会为父实体类生成单独的表。 以下语法表示按类表策略 - 连接策略示例 在这个例子中,我们将员工分为活跃员工和退休员工。 因此,子类和继承父类的和字段。 现在,按照以下步骤创建JPA项目 - 第1步: 在包下创建一个根实体类并指定所有必需的属性和注释。 文件:Employee.java - 第2步: 在包下创建实体类(
问题内容: 我尝试获取一些数据库值并将其显示在列表视图中。 这是我的代码: 我得到的RuntimeException 这是错误: 03-11 20:11:24.650:E / AndroidRuntime(887):java.lang.RuntimeException: 无法启动活动 ComponentInfo {com.NIRR.redistributionsystem / com.NIRR.r
我有一个奇怪的行为,JPA类层次结构使用一个表。基本上,我有两个实体EntityMap和EntityMapB,它们都扩展了EntityMaps。鉴别器值为“ENTITY_TYPE”,对于EntityMap为A,对于EntityApb为B。不知何故,我得到了EntityMapA类型的对象,其中鉴别器值设置为“B”! 我正在使用Hibernate 3.3作为JPA提供程序。 这是代码: 最后,我在En