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. Intellij笔记

    环境 官网: http://www.jetbrains.com/idea/download/ 需要Java的JDK,需要安装 JDK,而不是 JRE! http://www.oracle.com/te ...

  2. 我的ORM之一 -- 查询

    我的ORM索引 概述 http://code.taobao.org/svn/MyOql/ 这是我自己写的开源ORM教程,我想先从场景示例中切入介绍,先有一个感性的认识,以小见大,触类旁通,有了这个认识 ...

  3. 【C语言学习】《C Primer Plus》第11章 字符串和字符串函数

    学习总结 1.字符串(character String)是以空字符串(\o)结尾的char数组. 2.gets()方法代表get String,它从系统的标准输入设备(通常是键盘)获取一个字符串,当字 ...

  4. JavaScript使用DeviceOne开发实战(四)仿优酷视频应用

    开发之前需要考虑系统的差异性,比如ios手机没有回退键,所以在开发时一定要考虑二级界面需要有回退键,否则ios的手机就会陷入到这个页面出不去了.安卓系统有回退键,针对这个情况需要要求用户在3秒钟之内连 ...

  5. Java提高篇(三五)-----Java集合细节(一):请为集合指定初始容量

    集合是我们在Java编程中使用非常广泛的,它就像大海,海纳百川,像万能容器,盛装万物,而且这个大海,万能容器还可以无限变大(如果条件允许).当这个海.容器的量变得非常大的时候,它的初始容量就会显得很重 ...

  6. MySQL服务器安装配置-非安装版、windows版

    文档以5.6.30版本为例子说明 1. 下载MySQL http://dev.mysql.com/downloads/mysql/5.6.html#downloads 我们可以选择自己所需要的版本.环 ...

  7. 缓存篇~第七回 Redis实现基于方法签名的数据集缓存(可控更新,分布式数据缓存)

    返回目录 本篇文章可以说是第六回 Microsoft.Practices.EnterpriseLibrary.Caching实现基于方法签名的数据集缓存(可控更新,WEB端数据缓存)的续篇,事实上,有 ...

  8. [Maven]Eclipse插件之Maven配置及问题解析.

    前言:今天在自己环境装了Maven环境, 并且安装了Eclipse插件, 在查找插件过程中确实遇到一些问题, 好不容易找到一个  却又有问题.装好了插件之后, 用Eclipse创建Maven项目却出现 ...

  9. JDBC操作数据库,第一:jsp插入mysql数据库,坎坷摸索分享

    JSP连接数据库,坎坷摸索了好久,现在终于做好了,分享一下,希望对更多热爱编程学习的人有所帮助!!!谢谢 第一:首先准备的就是已经安装好Mysql,这里不做多叙述,百度可以做到. 然后在mysql数据 ...

  10. SQL Server排序函数row_number和rank的区别

    SQL Server排序函数row_number和rank的区别 直接看测试结果 declare @table table(name varchar(100),amount int, memo var ...