如何强制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文件中使用表/列名称,但是我想在全局范围内进行设置(以节省时间和防止错误)。
ImprovedNamingStrategy应该正是您想要的。参见3.6。实施命名策略。
ImprovedNamingStrategy