Создает ли Hibernate таблицы в базе данных автоматически - PullRequest
37 голосов
/ 22 декабря 2010

http://www.vaannila.com/spring/spring-hibernate-integration-1.html

Прочитав это руководство, они не упомянули ничего о создании таблиц в БД.Обрабатывает ли Hibernate это автоматически, создавая таблицы и поля, как только я их укажу.

Вот моя конфигурация бобов.

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:prefix="/WEB-INF/jsp/" p:suffix=".jsp" />

    <bean id="myDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://127.0.0.1:3306/spring"/>
        <property name="username" value="monwwty"/>
        <property name="password" value="www"/>
    </bean>

    <bean id="mySessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
        <property name="dataSource" ref="myDataSource" />
        <property name="annotatedClasses">
            <list>
                <value>uk.co.vinoth.spring.domain.User</value>
            </list>
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">create</prop>
            </props>
        </property>
    </bean>

    <bean id="myUserDAO" class="uk.co.vinoth.spring.dao.UserDAOImpl">
        <property name="sessionFactory" ref="mySessionFactory"/>
    </bean>

    <bean name="/user/*.htm" class="uk.co.vinoth.spring.web.UserController" >
        <property name="userDAO" ref="myUserDAO" />
    </bean>

</beans>

Ответы [ 7 ]

52 голосов
/ 22 декабря 2010

ваш параметр hibernate.hbm2ddl.auto должен определять, что база данных создана (варианты validate, create, update или create-drop)

23 голосов
/ 22 декабря 2010

Да, так и есть в вашем случае из-за свойства ниже в вашей конфигурации. Это нормально во время тестирования, но на производстве вам нужно отключить это.

<prop key="hibernate.hbm2ddl.auto">create</prop>
5 голосов
/ 09 марта 2016

добавьте следующее свойство в ваш файл hibernate.cfg.xml

<property name="hibernate.hbm2ddl.auto">update</property>

Кстати, в вашем классе Entity вы должны определить свой @Id, указанный как:

@Id
@GeneratedValue(generator = "increment")
@GenericGenerator(name = "increment", strategy = "increment")
@Column(name = "id")
private long id;

Если вы используете следующее определение, оно может не работать:

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private long id;
5 голосов
/ 12 февраля 2013

Для меня это не сработало даже с hibernate.hbm2ddl.auto, установленным на update.Оказалось, что сгенерированный SQL создания был недействительным, потому что одно из имен моих столбцов (user) было ключевым словом SQL.Это мягко провалилось, и не было очевидно, что происходило, пока я не проверил журналы.

5 голосов
/ 08 января 2012

Да, Hibernate можно настроить с помощью свойства hibernate.hbm2ddl.auto в файле hibernate.cfg.xml, чтобы автоматически создавать таблицы в вашей БД для хранения в них ваших сущностей, если таблица еще не существует.

Это может пригодиться во время разработки, когда можно использовать новую базу данных in-memory, и создавать новую при каждом запуске приложения или во время тестирования.

0 голосов
/ 12 ноября 2017

Hibernate может создавать таблицу, последовательность гибернации и таблицы, используемые для сопоставления «многие ко многим» от вашего имени, но вы должны явно настроить его, вызвав setProperty («hibernate.hbm2ddl.auto», «create») конфигурации объект. По умолчанию он просто проверяет схему с БД и завершается ошибкой, если ничего не существует, выдавая ошибку «ORA-00942: таблица или представление не существует».

Если вы выполните вышеуказанную настройку, порядок выполненных действий будет: a) Удалите все таблицы и последовательности и не выдайте ошибку, если они еще не присутствуют. б) создать всю таблицу и последовательность в) изменить таблицы с ограничениями г) вставить в него данные.

0 голосов
/ 02 декабря 2015

да, вы можете использовать

<property name="hbm2ddl.auto" value="create"/>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...