JPA配置详解之jpaProperties用法_第1页
JPA配置详解之jpaProperties用法_第2页
JPA配置详解之jpaProperties用法_第3页
JPA配置详解之jpaProperties用法_第4页
JPA配置详解之jpaProperties用法_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第JPA配置详解之jpaProperties用法目录JPA配置之jpaPropertiesSpingDataJpa配置问题perties.hibernate.hbm2ddl.auto=update

JPA配置之jpaProperties

xmlversion="1.0"encoding="UTF-8"

beansxmlns="/schema/beans"

xmlns:xsi="/2001/XMLSchema-instance"

xmlns:context="/schema/context"

xmlns:aop="/schema/aop"

xmlns:jpa="/schema/data/jpa"

xmlns:tx="/schema/tx"

xsi:schemaLocation="/schema/aop/schema/aop/spring-aop-4.1.xsd

/schema/beans/schema/beans/spring-beans.xsd

/schema/data/jpa/schema/data/jpa/spring-jpa-1.3.xsd

/schema/tx/schema/tx/spring-tx-3.2.xsd

/schema/context/schema/context/spring-context-4.1.xsd"

!--spring自动读取指定位置的配置为简到spring中--

context:property-placeholderlocation="classpath*:/perties"/

context:component-scanbase-package="com.shiroweb"

!--扫描com.shiroweb包下除去@Controller以外注解的类--

context:exclude-filtertype="annotation"expression="org.springframework.stereotype.Controller"/

context:exclude-filtertype="annotation"expression="org.springframework.web.bind.annotation.ControllerAdvice"/

/context:component-scan

!--c3p0数据源配置--

beanid="dataSource"

propertyname="driverClass"value="${jdbc.driver}"/

propertyname="jdbcUrl"value="${jdbc.url}"/

propertyname="user"value="${jdbc.username}"/

propertyname="password"value="${jdbc.password}"/

/bean

!--JpaEntityManager配置关联hibernateJpaVendorAdapter--

beanid="entityManagerFactory"

propertyname="dataSource"ref="dataSource"/

propertyname="jpaVendorAdapter"ref="hibernateJpaVendorAdapter"/

propertyname="packagesToScan"value="com.shiroweb"/

!--propertyname="jpaProperties"

props

命名规则My_NAME-MyName

propkey="hibernate.ejb.naming_strategy"org.hibernate.cfg.ImprovedNamingStrategy/prop

实体类对应数据库没有表就生成一个表

propkey="hibernate.hbm2ddl.auto"update/prop

/props

/property--

!--指定JPA属性;如Hibernate中指定是否显示SQL的是否显示、方言等--

propertyname="jpaProperties"

props

!--propkey="hibernate.dialect"org.hibernate.dialect.Oracle10gDialect/prop--

propkey="hibernate.ejb.naming_strategy"org.hibernate.cfg.ImprovedNamingStrategy/prop

!--propkey="vider_class"org.hibernate.cache.NoCacheProvider/prop--

propkey="hibernate.show_sql"true/prop

propkey="hibernate.format_sql"true/prop

!--propkey="hibernate.hbm2ddl.auto"validate/prop--

propkey="hibernate.hbm2ddl.auto"update/prop

/props

/property

/bean

!--配置hibernateJpaVendorAdapter关联数据源--

beanid="hibernateJpaVendorAdapter"

propertyname="database"value="MYSQL"/

propertyname="showSql"value="true"/

/bean

!--SpringDataJpa配置--

jpa:repositoriesbase-package="com.shiroweb"transaction-manager-ref="transactionManager"entity-manager-factory-ref="entityManagerFactory"/

!--Jpa事务配置--

beanid="transactionManager"

propertyname="entityManagerFactory"ref="entityManagerFactory"/

/bean

!--使用annotation定义事务--

tx:annotation-driventransaction-manager="transactionManager"proxy-target-/

/beans

其中jpaProperties是这是jpa的一些属性的

!--指定JPA属性;如Hibernate中指定是否显示SQL的是否显示、方言等--

propertyname="jpaProperties"

props

!--propkey="hibernate.dialect"org.hibernate.dialect.Oracle10gDialect/prop--

propkey="hibernate.ejb.naming_strategy"org.hibernate.cfg.ImprovedNamingStrategy/prop

!--propkey="vider_class"org.hibernate.cache.NoCacheProvider/prop--

propkey="hibernate.show_sql"true/prop

propkey="hibernate.format_sql"true/prop

!--propkey="hibernate.hbm2ddl.auto"validate/prop--

propkey="hibernate.hbm2ddl.auto"update/prop

/props

/property

这里有个属性为

propkey="hibernate.hbm2ddl.auto"update/prop

这是一个有用的设置

其实这个hibernate.hbm2ddl.auto参数的作用主要用于:自动创建|更新|验证数据库表结构。如果不是此方面的需求建议setvalue="none"。

create:每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。

create-drop:每次加载hibernate时根据model类生成表,但是sessionFactory一关闭,表就自动删除。

update:最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载hibernate时根据model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等应用第一次运行起来后才会。

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

SpingDataJpa配置问题

perties.hibernate.hbm2ddl.auto=update

在配置springdatajpa时,如果perties.hibernate.hbm2ddl.auto设置为update,会自动更新数据表结构,比如Entity中增加成员变量,数据表中也会增加相应的字段,但是需要注意的是,如果删除一个成员变量,这时数据表中不会自动删除对应的字段,如果删除的那个成员变量在数据表中被设置为notnull,当再次运行时就会报错,如下面的例子

新建一个实体类

importlombok.Data;

importjavax.persistence.*;

@Entity

@Data

publicclassCar{

@Column(name="id",nullable=false)

@GeneratedValue(strategy=GenerationType.IDENTITY)

privateLongid;

@Column(nul

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论