网络编程 
首页 > 网络编程 > 浏览文章

详解hibernate自动创建表的配置

(编辑:jimmy 日期: 2024/11/26 浏览:3 次 )

详解hibernate自动创建表的配置

配置自动创建表:

<prop key="hibernate.hbm2ddl.auto">update</prop>//首次创建项目时用,项目稳定后一般注释这里有4个值:
update:表示自动根据model对象来更新表结构,启动hibernate时会自动检查数据库,如果缺少表,则自动建表;如果表里缺少列,则自动添加列。

还有其他的参数:

create:启动hibernate时,自动删除原来的表,新建所有的表,所以每次启动后的以前数据都会丢失。
create-drop:启动hibernate时,自动创建表,程序关闭时,自动把相应的表都删除。所以程序结束时,表和数据也不会再存在。

validate :

每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。

然后在配置  读取实体类映射:

有3种方法:

1、(常用)通过注解扫描包的方式:

<property name="packagesToScan">
<list><value>com.systop.common.core.dao.testmodel</value></list>

2、通过注解的方式:

<property name="annotatedClasses"> 
 <list><value>com.systop.common.core.dao.testmodel.TestDept</value></list> 
</property> 


3、mappingResources用于指定少量的hibernate配置文件像这样

Xml代码

<property name="mappingResources"> 
   <list> 
  <value>WEB-INF/conf/hibernate/cat.hbm.</value> 
        <value>WEB-INF/conf/hibernate/dog.hbm.xml</value> 
        ...... 
   </list> 
</property> 

实例:

<bean id="propertyConfigurer"
   class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  <property name="locations">
    <list>
      <value>classpath*:/dataSource/jdbc.properties</value>
    </list>
  </property></bean><!-- 配置数据源 --><bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" >
  <property name="driverClassName" value="${jdbcCcbs.driverClassName}"/>
  <property name="url" value="${jdbcCcbs.url}"/>
  <property name="username" value="${jdbcCcbs.username}"/>
  <property name="password" value="${jdbcCcbs.password}"/></bean><!-- 配置SessionFactory--><bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"><!--<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">-->
  <property name="dataSource" ref="dataSource" />
  <property name="hibernateProperties">
    <props>
      <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
      <!--自动创建表配置-->
      <!--<prop key="hibernate.hbm2ddl.auto">update</prop>-->
      <prop key="hibernate.show_sql">true</prop>
      <prop key="hibernate.format_sql">true</prop>
      <!--结果滚动集,跟分页有关-->
      <prop key="jdbc.use_scrollable_resultset">false</prop>
    </props>
  </property>
  <!--<property name="annotatedClasses">-->
    <!--<list>-->
      <!--<value>com.jason.entity.UserEntity</value>-->
    <!--</list>-->
  <!--</property>-->
  <property name="packagesToScan">
    <list>
      <value>com.jason.entity</value>
    </list>
  </property></bean>

 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

上一篇:springMVC使用jsp:include嵌入页面的两种方法(推荐)
下一篇:详解Spring Hibernate连接oracle数据库的配置
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap