Ответ 1
параметр hibernate.hbm2ddl.auto должен определять, что создается база данных (параметры validate
, create
, update
или create-drop
)
http://www.vaannila.com/spring/spring-hibernate-integration-1.html
Прочитав этот учебник, они ничего не упомянули о создании таблиц в БД. Hibernate обрабатывает его автоматически, создавая таблицы и поля, когда я их укажу.
Вот моя конфигурация beans.
<?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>
параметр hibernate.hbm2ddl.auto должен определять, что создается база данных (параметры validate
, create
, update
или create-drop
)
Да, это происходит в вашем случае из-за свойства ниже в вашем конфиге. Это нормально во время тестирования, но в производстве вам нужно отключить это.
<prop key="hibernate.hbm2ddl.auto">create</prop>
Да, Hibernate можно настроить с помощью свойства hibernate.hbm2ddl.auto
в файле hibernate.cfg.xml
для автоматического создания таблиц в вашей БД, чтобы сохранить в них свои сущности, если таблица еще не существует.
Это может быть полезно во время разработки, где новая, in-memory,
БД может быть использована и создана новая при каждом запуске приложения или во время тестирования.
Для меня он не работал даже с hibernate.hbm2ddl.auto
, установленным на update
. Оказалось, что сгенерированное создание SQL было недопустимым, потому что одно из имен столбцов (user
) было ключевым словом SQL. Это провалилось мягко, и не было очевидно, что происходит, пока я не проверил журналы.
добавить в свой файл hibernate.cfg.xml следующее свойство
<property name="hibernate.hbm2ddl.auto">update</property>
BTW, в вашем классе 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;
Hibernate может создавать таблицу, последовательность спящего режима и таблицы, используемые для сопоставления "многие-ко-многим" от вашего имени, но вы должны явно настроить его, вызвав setProperty ( "hibernate.hbm2ddl.auto", "create" ) конфигурации объект. По умолчанию он просто проверяет схему с БД и терпит неудачу, если что-то еще не существует, указав ошибку "ORA-00942: таблица или представление не существует".
Если вы делаете выше конфигурации, то порядок выполненных действий будет: - a) Отбросьте все таблицы и последовательность и не выдавайте ошибку, если они еще не присутствуют. б) создать всю таблицу и последовательность c) изменять таблицы с ограничениями d) вставить в него данные.
Если свойство hibernate.ddl-auto = update
, то оно не будет создавать таблицы автоматически.
Для автоматического создания таблиц необходимо установить свойство
hibernate.ddl-auto = create
Список параметров, которые используются в весенней загрузке:
validate: проверка схемы, без изменений в базе данных.
обновить: обновить схему.
create: создает схему, уничтожая предыдущие данные.
create-drop: удалить схему в конце сеанса
нет: все остальные случаи
Таким образом, в первый раз вы можете установить его на create, а затем в следующий раз установить его на update.
да, вы можете использовать
<property name="hbm2ddl.auto" value="create"/>