Hibernate.cfg.xml配置分析讲解

来源:岁月联盟 编辑:zhuzhu 时间:2009-09-22

学习Hibernate时,经常会遇到Hibernate.cfg.xml配置问题,这里将介绍Hibernate.cfg.xml配置问题的解决方法。

Hibernate的描述文件可以是一个properties属性文件,也可以是一个xml文件。下面讲一下Hibernate.cfg.xml配置。配置格式如下:

1. 配置数据源

可以Hibernate.cfg.xml配置JDBC,也可以配置JNDI.在本小节中讲述数据源如何配置。

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <!DOCTYPE hibernate-configuration PUBLIC  
  3. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
  4. "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 
  5. <hibernate-configuration> 
  6. <session-factory> 
  7. <!-- 各属性的配置--> 
  8. <!—为true表示将Hibernate发送给数据库的sql显示出来 --> 
  9. <property name="show_sql">true</property> 
  10. <!-- SQL方言,这边设定的是MySQL --> 
  11. <property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property> 
  12. <!-- 一次读的数据库记录数 --> 
  13. <property name="jdbc.fetch_size">50</property> 
  14. <!-- 设定对数据库进行批量删除 --  
  15. <property name="jdbc.batch_size">30</property> 
  16. <!—下面为JNDI的配置 --> 
  17. <!-- 数据源的名称 --> 
  18. <property name="connection.datasource">java:comp/env/jdbc/datasourcename</property> 
  19. <!-- Hibernate的连接加载类 --> 
  20. <property name="connection.provider_class">net.sf.hibernate.
    connection.DatasourceConnectionProvider</property> 
  21. <property name="dialect">net.sf.hibernate.dialect.SQLServerDialect</property> 
  22. <!—映射文件 --> 
  23. <mapping resource="com/amigo/pojo/User.hbm.xml"/> 
  24. <mapping resource="com/amigo/pojo/Org.hbm.xml"/> 
  25. </session-factory> 
  26. </hibernate-configuration> 

2. c3p0连接池

c3p0连接池是Hibernate推荐使用的连接池,若需要使用该连接池时,需要将c3p0的jar包加入到classpath中。c3p0连接池的配置示例如下:

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <!DOCTYPE hibernate-configuration PUBLIC  
  3. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
  4. "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 
  5. <hibernate-configuration> 
  6. <session-factory 
  7. <!-- 显示实际操作数据库时的SQL --> 
  8. <property name="show_sql">true</property> 
  9. <!-- SQL方言,这边设定的是MySQL --> 
  10. <property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property> 
  11. <!--驱动程序,在后续的章节中将讲述mysql、sqlserver和Oracle数据库的配置 --> 
  12. <property name="connection.driver_class">……</property 
  13. <!-- JDBC URL --> 
  14. <property name="connection.url">……</property> 
  15. <!-- 数据库用户名 --> 
  16. <property name="connection.username">user</property> 
  17. <!-- 数据库密码 --> 
  18. <property name="connection.password">pass</property> 
  19. <property name="c3p0.min_size">5</property 
  20. <property name="c3p0.max_size">20</property> 
  21. <property name="c3p0.timeout">1800</property> 
  22. <property name="c3p0.max_statements">50</property> 
  23. <!-- 对象与数据库表格映像文件 --> 
  24. <mapping resource="com/amigo/pojo/User.hbm.xml"/> 
  25. <mapping resource="com/amigo/pojo/Org.hbm.xml"/> 
  26. </session-factory> 
  27. </hibernate-configuration> 

在上述配置中,Hibernate根据配置文件生成连接,再交给c3p0管理。