1.Hibernate 配置文件主要用于配置**数据库连接**和 Hibernate 运行时所需的**各种属性**。

2.每一个 Hibernate 配置文件对应一个 Configuration 对象,从前一篇文章知道,可以通过 Configuration 的 configure() 方法来读取 Hibernate 的配置文件,默认读取 `hibernate.cfg.xml`。

3.配置数据库连接的基本信息,在 <session-factory> 节点内配置。

(1)JDBC 连接属性

<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>

(2)使用 C3p0 数据源

①导入 Jar 包

②配置

<!-- 配置最大连接数 -->
<property name="c3p0.max_size">20</property>
<!-- 配置最小连接数 -->
<property name="c3p0.min_size">5</property>
<!-- 缓存 statement 对象 -->
<property name="c3p0.max_statements">10</property>
<!-- 连接池中连接耗尽时,向数据库一次要多少个连接 -->
<property name="c3p0.acquire_increment">10</property>
<!-- 超时时间 -->
<property name="c3p0.timeout">2000</property>
<!-- 检测线程每隔多长时间检测一次池内所有连接是否超时 -->
<property name="c3p0.idle_test_period">2000</property>

(3)数据库方言的配置

<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>

tip: Mysql 的 InnoDB 引擎在进行数据操作时,会进行锁行,而不是锁表。在高并发的情况下,使用 InnoDB 引擎较好。

4.常用属性

(1)是否打印 sql,取值 true/false

<property name="show_sql">true</property>

(2)打印的 sql 是否进行格式化,取值 true/false

<property name="format_sql">true</property>

5.建表策略

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

取值: create|upadte|create-drop|validate

(1)create 不论是否更改了表结构,每次都重新创建表。

(2)upadte 只有在更改了表结构的前提下,才会去更新表,但是不会删除已有的数据。

(3)create-drop 回根据 hibernate.cfg.xml 文件生成表,但是 SessionFactory 一关闭,表就自动删除。

(4)validate 会和数据库中的表进行比较,若 hibernate.cfg.xml 文件中的列在数据表中不存在,则抛出异常。

6.jdbc.fetch_size 和 jdbc.batch_size (Mysql 不支持)

(1)hibernate.jdbc.fetch_size:实质是调用 Statement.setFetchSize() 方法,设定 JDBC 的 statement 读取数据时,每次从数据库中取出的记录的条数。

Oracle 支持 Fetch Size 特性,当 fetchSize = 100 的时候,性能最好。

(2)hibernate.jdbc.batch_size:设定对数据库进行批量删除、批量更新、批量插入的时候的批次大小。

Oracle 数据库 batchSize =30 的时候比较合适。

7. 配置 Entity.hbm.xml 文件

<mapping resource="com/nucsoft/hibernate/News.hbm.xml"/>

8.总结

介绍了 Hibernate 配置文件,包括基本配置与 Hibernate 本身的配置。

补充:

hibernate.cfg.xml 配置文件:

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 配置连接数据库的基本信息 -->
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property> <!-- 配置c3p0 数据源信息 -->
<!-- 配置最大连接数 -->
<property name="c3p0.max_size">20</property>
<!-- 配置最小连接数 -->
<property name="c3p0.min_size">5</property>
<!-- 缓存 statement 对象 -->
<property name="c3p0.max_statements">10</property>
<!-- 连接池中连接耗尽时,向数据库一次要多少个连接 -->
<property name="c3p0.acquire_increment">10</property>
<!-- 超时时间 -->
<property name="c3p0.timeout">2000</property>
<!-- 检测线程每隔多长时间检测一次池内所有连接是否超时 -->
<property name="c3p0.idle_test_period">2000</property> <!-- 配置 Hibernate 的基本信息 -->
<property name="show_sql">true</property>
<property name="format_sql">true</property> <!-- 指定自动生成数据表的策略 -->
<property name="hbm2ddl.auto">update</property> <!-- mysql 不支持此特性 -->
<property name="hibernate.jdbc.batch_size">30</property>
<!-- mysql 不支持此特性 -->
<property name="hibernate.jdbc.fetch_size">100</property> <!-- 需要关联的 Entity.hbm.xml -->
<mapping resource="com/nucsoft/hibernate/News.hbm.xml"/>
</session-factory>
</hibernate-configuration>

Hibernate —— Hibernate 配置文件的更多相关文章

  1. 3.一起来学hibernate之配置文件2

    之前的映射文件配置都是简单的.基础的配置,只涉及到单个javabean,对于单个javabean的增删改查都能很好的.简单的去完成. 但是知道简单配置远远不够,并不能完成很多复杂的情况,比如对象与对象 ...

  2. 2.一起来学hibernate之配置文件1与持久化对象

    学框架,配置都是不可少的,有了配置,框架才知道我们想做什么,才知道如何去执行我们需要的操作! hibernate的配置文件,总体来说分为两个部分: 1.主配置文件hibernate.cfg.xml文件 ...

  3. Hibernate的配置文件以及用法

    一. 三大框架 Hibernate 1.安装hibernate插件至ecilpse 2.进行配置 2.1 主配置文件 <?xml version="1.0" encoding ...

  4. eclipse 新建 maven 项目 添加 spring hibernate 的配置文件 详情

    主要配置文件 pom.xml 项目的maven 配置文件 管理项目所需 jar 依赖支持 web.xml 项目的总 配置文件  :添加 spring和hibernate 支持 applicationC ...

  5. Hibernate常用配置文件详解

    本文转载自:http://blog.csdn.net/csh624366188/article/details/7578939 初学hibernate的童鞋,刚开应该都有这种感觉,hibernate的 ...

  6. Hibernate的配置文件解析

    配置mybatis.xml或hibernate.cfg.xml报错: <property name="connection.url">jdbc:mysql://loca ...

  7. hibernate通过配置文件生成数据库信息

    hibernate可以通过配置文件在数据库生成相应的数据库信息.也可以把数据库的信息生成相应的代码(实体类操作类和映射文件) 下面是通过代码默认对hibernate.cfg.xml信息在数据库生成信息 ...

  8. hibernate 基本配置文件及CRDU的操作和基本的HQL查询

    以下所有内容保存在 E:\JavaWebSrc\firstHibernate 目录中,项目名称为firstHibernate,使用IDEA打开,项目所需jar包在  F:\常用综合\常用jar包\hi ...

  9. 1-2 hibernate主配置文件hibernate.cfg.xml详解

    详 http://www.cnblogs.com/biehongli/p/6531575.html Hibernate的主配置文件hibernate.cfg.xml 1:Hibernate的主配置文件 ...

随机推荐

  1. asp.net identity 2.2.0 中角色启用和基本使用(四)

    创建角色相关视图 第一步:添加视图   打开RolesAdminController.cs   将鼠标移动到public ActionResult Index()上  右键>添加视图   系统会 ...

  2. 前端神器avalonJS入门(二)

    本章开始搭配requireJS来使用avalon,开始之前,我们可以对avalon进行精简改造(注:新版的avalon已提供了shim版本,无需再做如下的精简了,直接点这里获取). avalon源码里 ...

  3. .net开发笔记(十八) winform中的等待框

    winform中很多任务是需要在后台线程(或类似)中完成的,也就是说,经常容易涉及到UI界面与后台工作线程之间的交互.比如UI界面控制后台工作的执行(启动.暂停.停止等),后台工作进度在UI界面上的显 ...

  4. Entity Framework 5.0系列之约定配置

    Code First之所以能够让开发人员以一种更加高效.灵活的方式进行数据操作有一个重要的原因在于它的约定配置.现在软件开发越来复杂,大家也都试图将软件设计的越来越灵活,很多内容我们都希望是可配置的, ...

  5. [.net 面向对象编程基础] (6) 基础中的基础——运算符和表达式

    [.net 面向对象编程基础] (6) 基础中的基础——运算符和表达式 说起C#运算符和表达式,小伙伴们肯定以为很简单,其实要用好表达式,不是一件容易的事.一个好的表达式可以让你做事半功倍的效果,比如 ...

  6. TCP Server—Linux

    #include <stdio.h> #include <netinet/ip.h> #define BUFF_SIZE 1024 int main(int argc,char ...

  7. mysql --prompt

    mysql --prompt修改命令行链接mysql时的提示符,shell脚本示例如下 #!/bin/bash in crm) cmd='mysql -h192.168.1.2 -uroot -pro ...

  8. 为什么说Java中的随机数都是伪随机数?

    什么是伪随机数?  1.伪随机数是看似随机实质是固定的周期性序列,也就是有规则的随机. 2.只要这个随机数是由确定算法生成的,那就是伪随机,只能通过不断算法优化,使你的随机数更接近随机.   (随机这 ...

  9. 说说设计模式~策略模式(Strategy)

    返回目录 策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换.而对于客户端(UI)来说,可以通过IOC再配合工厂模块,实现动态策略的切换,策略模块通常于一个抽象策略对象(in ...

  10. [Java面试七]Mybatis总结以及在面试中的一些问题.

    1.JDBC编程有哪些不足之处,MyBatis是如何解决这些问题的? ① 数据库链接创建.释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库链接池可解决此问题. 解决:在SqlMapConfig ...