在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:设置是否自动提交,通常不建议开启自动提交