首页 > 编程 > JSP > 正文

Hibernate 主清单文件配制的详细介绍

2020-07-27 21:19:57
字体:
来源:转载
供稿:网友

Hibernate 主清单文件配制的详细介绍

1 Hiernate 清单配制文件

方式一 在工程src目录下创建 hibernate.cfg.xml 文件

 Hiernate 开始加载时,会默认的方式去工程src目录下扫描 hibernate.cfg.xml文件,然后加载配制 
public class H3Utils {private static SessionFactory factory = new Configuration().configure().buildSessionFactory();  /**   * 获得线程绑定的session   * @return   */  public static Session getCurrentSession(){    return factory.getCurrentSession();  }}

方式二 在工程中的任何目录下创建 hibernate.cfg.xml 文件

    这种方式的时候,需要在使用的时候 手动指定配制文件的路径

public class HBUtils {  //提供一个工厂 (链式操作)  private static SessionFactory factory =     new Configuration()      .configure("android/longs/study/config/hibernate.cfg.xml")      .buildSessionFactory();  /**   * 获得新的会话   * @return   */  public static Session openSession(){  return factory.openSession() ;  }  /**   * 获得当前线程中绑定的session   * @return   */  public static Session getCurrentSession(){  return factory.getCurrentSession();  }}

2 Hiernate 清单配制文件 详情

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE hibernate-configuration PUBLIC  "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"><hibernate-configuration>  <session-factory>    <!-- 1 基本4项 -->    <!-- 1.1 加载驱动配制 -->    <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>    <!-- 1.2 数据库地址 -->    <!-- 如 jdbc:mysql://192.168.1.1:3306/test_java_study?useUnicode=true&amp;characterEncoding=UTF-8-->    <property name="hibernate.connection.url">url</property>    <!-- 1.3 登录数据库用户名 -->    <property name="hibernate.connection.username">root</property>    <!-- 1.3 登录数据库用户名密码 -->    <property name="hibernate.connection.password">123456</property>    <!-- 2 方言 -->    <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>    <!-- 3 开发时,优化设置 -->    <!-- 3.1 显示生产sql语句 -->    <property name="hibernate.show_sql">true</property>    <!-- 3.2 格式化方式显示sql -->    <property name="hibernate.format_sql">true</property>    <!-- 4 表的创建 -->    <property name="hibernate.hbm2ddl.auto">update</property>    <!-- 5 取消bean校验 -->    <property name="javax.persistence.validation.mode">none</property>    <!-- 6 将session绑定当本地线程中 * hibernate session 管理 : 只将使用。 * 当在cfg.xml 配置 thread,SessionFactory提供       getCurrentSession() 将可以使用。 * hibernate底层使用 ThreadLocal 线程局部变量,可以在一个线程中共享数据。       *** get() ##map.get(Thread) *** set(value) ##map.put(Thread,value) *** remove()       ##map.remove(Thread) -->    <property name="hibernate.current_session_context_class">thread</property>    <!-- 整合c3p0 -->    <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>    <!-- 对象类的 映射文件 -->    <mapping resource="android/longs/study/home/servlet/model/MobleHomeModel.hbm.xml" />  </session-factory></hibernate-configuration>

关于 第四项 表的创建中

取值可为   create : 每一次都将创建表,如果表已经存在将删除。(测试)程序结束之后,表存在的。  create-drop:每一次都将创建表,如果表已经存在将删除。(测试)程序结束之后,将删除表。          注意:必须执行 factory.close() 否则与“create”相同  update : 如果表不存在,将创建。如果存在,将维护对应关系(映射文件 - 表)【】          注意:只负责添加,但不进行删除。  validate : 运行时,将校验 映射文件 和 表 对应关系,如果一一对应程序正常运行,如果不对应抛异常。

二级缓存配制

   <!-- 配置隔离级别 -->    <property name="hibernate.connection.isolation">4</property>    <!-- 开启二级缓存 -->    <property name="hibernate.cache.use_second_level_cache">true</property>    <!-- 提供商 -->    <property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>    <!-- 开启查询缓存 -->    <property name="hibernate.cache.use_query_cache">true</property>    <!-- 二级缓存监测 -->    <property name="hibernate.generate_statistics">true</property>    <!-- 类缓存 -->    <!-- com包下的Customer类 -->    <class-cache usage="read-write" class="com.Customer"/>    <!-- com包下的Order包 -->    <class-cache usage="read-write" class="com.Order"/>    <!-- 集合缓存 -->    <!-- com包下的Customer类中的orderSet集合 -->    <collection-cache usage="read-write" collection="com.Customer.orderSet"/>

注意 

    一级缓存缓存的是对象 

    二级缓存缓存的是数据 

       二级缓存中集合缓存中的对象未进行类缓存的话,将会执行OID查询

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表