一尘不染

在休眠状态下使用下划线生成的列和表名称

hibernate

如何强制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文件中使用表/列名称,但是我想在全局范围内进行设置(以节省时间和防止错误)。


阅读 215

收藏
2020-06-20

共1个答案

一尘不染

ImprovedNamingStrategy应该正是您想要的。参见3.6。实施命名策略

2020-06-20