在Hibernate中的一个关键步骤就是配置文档,配置文档有三种形式:hibernate.properties、hibernate.cfg.xml、硬编码方式。这里不对三种方式做具体讨论,只是总结一下配置文件中的各种属性极其作用。

配置文件中的属性可以分为以下几类:

1、JDBC连接属性

2、C3P0连接池

3、数据库方言

4、JNDI数据源的连接属性

5、Hibernate事物属性

6、二级缓存的相关属性

7、外连接抓取属性

8、其他常用属性

JDBC连接属性:


Hibernate需要连接数据库,因此JDBC连接属性是必需的


hibernate.connection.driver_class:设置连接数据库的驱动


hibernate.connection.url:设置所需连接数据库的URL


hibernate.connection.username:设置连接数据库的用户名


hibernate.connection.password:设置连接数据库的密码


hibernate.connection.pool_size:设置Hibernate数据库连接池的最大并发数


Hibernate自带的连接池仅有测试价值,并不推荐在实际项目中使用,实际项目中可以使用C3P0或Proxool连接池。


C3P0连接池属性:


connection.provider_class:使用C3P0连接池,配置连接池提供商


c3p0.min_size:连接池中可用的数据库连接的最小数目


c3p0.max_size:连接池中可用的数据库连接的最大数目


c3p0.timeout:设定数据库连接池的过期时间,以秒为单位,如果数据库连接池中的某个数据库连接处于空闲状态的时间超过了timeout时间,就会从连接池中清除


c3p0.idle_test_period:设定检查连接池中所有空闲连接的时间,以秒为单位


数据库方言:


Hibernate底层依然使用SQL语句来执行对数据库的操作,只要为Hibernate设置了合适的数据库方言,Hibernate将可以自动的应付底层数据库访问所存在的细节差异。


数据库方言属性:


hibernate.dialect:设置连接数据库所使用的方言


JNDI数据源的连接属性:


如果无须Hibernate自己管理数据源,而是直接访问容器管理数据元,Hibernate可以使用JNDI(Java Naming Directory Interface,Java命名目录接口)数据源的相关配置。


hibernate.connection.datasource:指定数据源JNDI名字


hibernate.jndi.url:指定JNDI提供者的URL,该属性是可选的。如果JNDI与Hibernate持久化访问的代码处于同一个应用中,则无须指定该属性


hibernate.jndi.class:指定JNDI InitialContextFactory的实现类,该属性业是可选的。如果JNDI与Hibernate持久化访问的代码处于同一个应用中,则无须指定该属性


hibernate.connection.username:指定连接数据库的用户名,该属性是可选的


hibernate.connection.password:指定连接数据库的密码,该属性是可选的


Hibernate的事务属性:


事务也是Hibernate持久层访问的重要方面,Hibernate不仅提供了局部事务支持,也允许使用容器管理的全局事务。Hibernate关于事务管理的属性:


hibernate.transaction.factory_class:指定Hibernate所用的事务工厂的类型,该属性值必须是TransactionFactory的直接或间接子类


jta.UserTransaction:该属性是一个JNDI名,Hibernate将使用JTATransactionFactory从应用服务器获取JTA UaerTransaction


hibernate.transaction.manager_lookup_class:该属性值应为一个TransactionManagerLookup类名,当使用JVM级别的缓存时,火灾JTA环境中使用hilo生成器策略时,需要该类


hibernate.transaction.flush_before_completion:指定Session是否在食物完成后自动将数据刷新到底层数据库。该属性只能为true或false。现在更好的方法是使用Context相关的Session管理


hibernate.transaction。auto_close_session:指定是否在事务结束后自动关闭Session。该属性值只能是true或false,现在更好的方法是使用Context相关的Session管理


二级缓存的相关属性:


Hibernate的SessionFactory可持有一个可选的二级缓存,通过使用这种二级缓存可以提高Hibernate的持久化访问的性能。


hibernate.cache.provider_class:该属性用于设置二级缓存CacheProvider的类名


hibernate.cache.use_minimal_puts:以频繁的度操作为代价,优化二级缓存以实现最小化写操作。在Hibernate 3中,这个设置对集群缓存非常有用,对集群缓存的实现而言,默认是开启的


hibernate.cache.use_query_cache:设置是否允许查询缓存。个别查询仍然需要显示设置为可缓存的


hibernate.chche.query_cache_factory:设置查询缓存工厂的类名,查询缓存工厂必须实现QueryCache接口。该属性默认为内建的StandardQueryCache


hibernate.cache.region_prefix:设置二级缓存去名称前缀


hibernate.cache.use_structured_entries:用于设置是否强制Hibernate以可读性更好的格式将数据存入二级缓存


外连接抓取属性:


外连接抓取能限制执行SQ语句的次数来提高效率,这种外连接抓取属性通过在单个select语句中使用outer join来一次抓取多个数据表的数据。


外连接抓取允许在单个select语句中,通过<many-to-one>、<one-to-many>、<many-to-many>、<one-to-one>等关联获取连接对象的整个对象图。


将hibernate.max_fetch_depth设为0,将在全局范围内禁止外连接抓取,设为1或更高值能启用N-1或1-1的外连接抓取。除此之外,还应该在映射文件中通过fetch="join"laizhiding来指定这种外连接抓取。


其他常用属性:


hibernate.show_sql:是否在控制台输出Hibernate生成的SQL语句,只能为true和false两个值。




hibernate.format_sql:是否将SQL语句转成格式良好的SQL,只接受true和false两个值


hibernate.use_sql_comments:是否在Hibernate生成的SQL语句中添加有助于调试的注释,只接受true和false两个值


hibernate.jdbc.fetch_size:指定JDBC抓取数量的大小,它可以接受一个整数值,其实质是掉哦那个Statment.setFetchSize()方法


hibernate.jdbc.batch_size:指定Hibernate使用JDBC2的批量更新的大小,它可以接受一个整数值,建议取5到30之间的值


hibernate.connection.autocommit:设置是否自动提交,通常不建议开启自动提交