Сгенерированные имена столбцов и таблиц в 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-файл, но я хочу установить его глобально (как для экономии времени, так и для предотвращения ошибок).
2 ответов
ImprovedNamingStrategy
должны делать именно то, что вы хотите. См.3.6. Реализация NamingStrategy.
на JPA 2 (спящий режим 4), это еще проще!--6-->, просто добавьте:
<property name="hibernate.ejb.naming_strategy"
value="org.hibernate.cfg.ImprovedNamingStrategy" />
на persistence.xml
.