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

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查询

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

相关文章