Сгенерированные имена столбцов и таблиц в спящем режиме с подчеркиванием

как заставить hibernate генерировать db-схему таким образом, чтобы она преобразовывала CamelCase в Underscores (используя 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, но я хочу установить его глобально (как для экономии времени, так и для предотвращения ошибок).

Ответ 2

В JPA 2 (Hibernate 4), это еще проще, просто добавьте:

<property name="hibernate.ejb.naming_strategy"
         value="org.hibernate.cfg.ImprovedNamingStrategy" />

на ваш persistence.xml.