TA的每日心情 | 开心 2021-3-12 23:18 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- DatabaseConnection settings(数据库连接设置) -->
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<property name="connection.url">
jdbc:mysql://localhost:3306/MyProject
</property>
<property name="connection.username">root</property>
<property name="connection.password">zhangjie</property>
<!-- hibernate自带连接池参数 -->
<property name="connection.pool_size">1</property>
<!-- SQL dialect(SQL方言) -->
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<!-- 设定Hibernate自动管理session上下文 -->
<property name="current_session_context_class">thread</property>
<!-- 禁用二级缓存 -->
<property name="cache.provider_class">
org.hibernate.cache.NoCacheProvider
</property>
<!-- 如果存在表则drop,然后再创建,如果没有,则直接创建 -->
<property name="hbm2ddl.auto">create</property>
<!-- 在控制台显示执行的SQL -->
<property name="show_sql">true</property>
<!-- 映射资源 -->
<mapping resource="ch03/hibernate/User.hbm.xml" />
</session-factory>
</hibernate-configuration>
对于 hbm2dll.auto 各个取值的意义如下:
1.create-drop : hibernate一开始就发送一个drop语句,再执行create语句创建表,当sessionFactory关闭时又执行drop语句删除表。结果就是,当表存在时,首先会被drop掉,然后又创建,最终被drop,如果表不存在,一开始虽然hibernate还是会发送drop语句,当时因为表不存在而drop失败。
2.create:hibernate首先会发送一个drop语句,如果表存在则会被drop掉,然后hibernate再发送create语句创建表。
3.update:hibernate会首先查询数据库看是否存在此表,如果存在则不管,如果不存在则会先发送一个create语句创建一个表。
4.validate:每次插入数据之前都会验证数据库中的表结构和hbm文件的结构是否一致。如果表不存在,则报错。
current_session_context_class:
sessionFactory.getCurrentSession()可以完成一系列的工作,当调用时,
hibernate将session绑定到当前线程,事务结束后,hibernate
将session从当前线程中释放,并且关闭session。当再次调用getCurrentSession
()时,将得到一个新的session,并重新开始这一系列工作。
|
|