天天看点

jpa配置

JPA规范要求在类路径(Eclipse工程的src目录)的META-INF目录下放置persistence.xml, 文件的名称是固

定的,配置模板(此处是针对Hibernate)如下:

<?xml version="1.0"?>

<persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-xsi:schemaLocation="http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0">

<persistence-unit name="itcast" transaction-type="RESOURCE_LOCAL">

<properties>

<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect" />

<property name="hibernate.connection.driver_class" value="org.gjt.mm.mysql.Driver" />

<property name="hibernate.connection.username" value="root" />

<property name="hibernate.connection.password" value="123456" />

<property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/itcast?useUnicode=<property name="hibernate.max_fetch_depth" value="3" />

<property name="hibernate.show_sql" value="true" />

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

</properties>

</persistence-unit>

</persistence>

说明:

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

面的需求建议set value="none"。里面可以设置的几个参数:

? validate 每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新

表,但是会插入新值。

? create 每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新

表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。

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

? update 最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立

好数据库),以后加载hibernate时根据 model类自动更新表结构,即使表结构改变了但表中的行仍然

存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等应用

第一次运行起来后才会。

总结:

? 请慎重使用此参数,没必要就不要随便用。

? 如果发现数据库表丢失,请检查hibernate.hbm2ddl.auto的配置