http://www.vaannila.com/spring/spring-hibernate-integration-1.html
阅读本教程后,他们没有提到在DB中创建表的任何内容.一旦我指定它们,Hibernate是否通过创建表和字段来自动处理它.
这是我的bean配置.
<?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>
Run Code Online (Sandbox Code Playgroud)
Ara*_*ram 23
是的,因为您的配置中包含以下属性.这在测试期间没问题,但在生产中你需要禁用它.
<prop key="hibernate.hbm2ddl.auto">create</prop>
Run Code Online (Sandbox Code Playgroud)
小智 6
是的,可以通过文件中的hibernate.hbm2ddl.auto属性配置Hibernate hibernate.cfg.xml,以便在数据库中自动创建表,以便在表尚不存在时将实体存储在其中.
这在开发过程中非常方便,in-memory,可以在每次运行应用程序或测试期间使用新的DB并创建新的DB.
对我而言,即使hibernate.hbm2ddl.auto设置为,也无法正常工作update.原来,生成的创建SQL无效,因为我的一个列名(user)是一个SQL关键字.这很失败,直到我检查日志才明白发生了什么.
在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;
Run Code Online (Sandbox Code Playgroud)
如果您使用以下定义,它可能不起作用:
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private long id;
Run Code Online (Sandbox Code Playgroud)
小智 5
如果属性hibernate.ddl-auto = update,那么它不会自动创建表。要自动创建表,需要将属性设置为
hibernate.ddl-auto = create
Spring Boot 中使用的选项列表是
validate:验证架构,不对数据库进行任何更改。
更新:更新架构。
create:创建模式,销毁以前的数据。
create-drop:在会话结束时删除模式
none : 是所有其他情况
因此,第一次您可以将其设置为create,然后下次您应该将其设置为update。
| 归档时间: |
|
| 查看次数: |
99290 次 |
| 最近记录: |