如何强制hibernate生成数据库模式,以便将CamelCase转换为下划线(使用HBM)?例如。我有:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cz.csas.pdb.be.model.product.passive">
<class name="foo.BarBaz">
<id name="barBazId">
<generator class="sequence"/>
</id>
<property name="extractContactType"/>
<!-- ... -->
</class>
</hibernate-mapping>
我希望hibernate创建这样的表(oracle):
CREATE TABLE "BAR_BAZ"
(
"BAR_BAZ_ID" NUMBER(19,0) NOT NULL ENABLE,
"EXTRACT_CONTACT_TYPE" VARCHAR2(512 CHAR),
-- PK etc...
)
我知道我可以在hbm.xml文件中使用表/列名,但我想全局设置它(既节省时间又防止错误)。
答案 0 :(得分:7)
ImprovedNamingStrategy
应该完全按照您的意愿行事。请参阅3.6. Implementing a NamingStrategy。
答案 1 :(得分:5)
在 JPA 2 (Hibernate 4),it is even more easier中,只需添加:
<property name="hibernate.ejb.naming_strategy"
value="org.hibernate.cfg.ImprovedNamingStrategy" />
到persistence.xml
。