1

我正在从数据库生成 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”这样的方法来进行反向名称转换。知道我错过了什么吗?再次感谢

4

1 回答 1

3

您可以为逆向工程策略创建一个类,该类扩展任何已定义的策略,如“DelegateRevereseEngineeringStrategy”或“DefaultReverseEngineeringStrategy”。然后,覆盖提供的方法

  1. 要排除列,请覆盖以下方法

    public boolean excludeColumn(TableIdentifier identifier, String columnName) {
      if(columnName.startsWith("uid_")) {
         return true;
      }
      return delegate==null?false:delegate.excludeColumn(identifier, columnName);
    }
    
  2. 要从基类扩展生成的类,请使用方法添加元属性

    public Map<String, MetaAttribute> tableToMetaAttributes(TableIdentifier tableIdentifier) {
    
      Map<String, MetaAttribute> metaAttributes = super.tableToMetaAttributes(tableIdentifier);
    
      if(metaAttributes == null) {
        metaAttributes = new HashMap<String, MetaAttribute>();
      }
      // All generated classes will extend com.abc.Test class
      MetaAttribute extendsAttribute = new MetaAttribute("extends");
      extendsAttribute.addValue("com.abc.Test");
      metaAttributes.put("extends", extendsAttribute);
      return metaAttributes;
    }
    

您也可以使用 reveng.xml 文件执行这些操作。有关更多提示,请参阅此帖子

于 2013-04-25T05:41:18.890 回答