我正在从数据库生成 java 类(使用 Hiberndate 逆向工程)。我生成的所有类都将具有这样的内容(只是为了确保 uid_xxxxx 是数据库表中的主键):
private Integer uidCompany;
@Id
@GeneratedValue(strategy = IDENTITY)
@Column(name = "uid_company", unique = true, nullable = false)
public Integer getUidCompany() {
return this.uidCompany;
}
public void setUidCompany(Integer uidCompany) {
this.uidCompany = uidCompany;
}
所以我写了这个类:
@MappedSuperclass
public abstract class HibernateObject implements Serializable {
protected Integer uniqueID;
@Id
@GeneratedValue(strategy = IDENTITY)
public Integer getUniqueID() {
return this.uniqueID;
}
public void setUniqueID(Integer aUID) {
this.uniqueID = aUID;
}
}
我希望从休眠逆向工程生成的所有类来扩展它。正如您可能猜到的那样,我还希望不创建“uid_xxxxx”属性,而是将值保存到父属性“uniqueID”中。我可以手动完成,但我经常发现自己必须重新生成我的类,这就是为什么我希望逆向工程过程来完成它。
我环顾四周,发现这些链接很有用,但我想我仍然缺少一些东西。任何帮助,将不胜感激!
http://ocpsoft.org/java/hibernate-use-a-base-class-to-map-common-fields/
http://www.myeclipseide.com/documentation/quickstarts/hibernate/
如何使用 Hibernate/JPA 注释覆盖 GenerationType 策略?
/******************************************EDIT******************************/
所以这就是我在阅读你的建议后得到的结果:
好的,所以我按照您的指示进行操作,结果如下:
public abstract class HibernateObject implements Serializable {
public abstract Integer getUniqueID();
public abstract void setUniqueID(Integer aUID);
}
和
public class MyReverseEngineeringStrategy extends DelegatingReverseEngineeringStrategy {
public MyReverseEngineeringStrategy(ReverseEngineeringStrategy aDelegate) {
super(aDelegate);
}
@Override
public String columnToPropertyName(TableIdentifier table, String column) {
if(column.startsWith("uid_")) {
return "uniqueID";
}
else {
return super.columnToPropertyName(table, column);
}
}
@Override
public Map<String, MetaAttribute> tableToMetaAttributes(TableIdentifier tableIdentifier) {
@SuppressWarnings("unchecked")
Map<String, MetaAttribute> metaAttributes = super.tableToMetaAttributes(tableIdentifier);
if(metaAttributes == null) {
metaAttributes = new HashMap<String, MetaAttribute>();
}
// All generated classes will extend utils.HibernateObject class
MetaAttribute extendsAttribute = new MetaAttribute("extends");
extendsAttribute.addValue("utils.HibernateObject");
metaAttributes.put("extends", extendsAttribute);
return metaAttributes;
}
}
现在我所有的hibernate方法都扩展了HibernateObject,并且由于id的参数被命名为“uniqueID”,代码生成器创建的getter和setter覆盖了所需的函数。
我仍然有一个(小)问题:当我使用这样的 HQL 查询语言时: List picklist = session.createQuery("FROM Picklist").list();
我收到这样的错误:“org.hibernate.exception.SQLGrammarException: Unknown column 'picklist0_.uniqueID' in 'field list'”
我知道我收到此错误是因为我的 DataBase 表中没有这样的字段,我认为这是因为 hibernate 尝试从它生成的属性名称中获取字段名称。但是,在 DelegatingReverseEngineeringStrategy 中没有像“PropertyNameToColumn”这样的方法来进行反向名称转换。知道我错过了什么吗?再次感谢