配置文件默认为:hibernate.cfg.xml
Hibernater初始化期间会自动在CLASSPATH中寻找这个文件,并读取其中的配置信息,为后期数据库操作做好准备。
配置文件应部署在CLASSPATH中,对于Web应用而言,配置文件应放置在\WEB-INF\classes,目录下
配置文件内容:
<?xml version='1.0' encoding='UTF-8'?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <!-- Generated by MyEclipse Hibernate Tools. --> <hibernate-configuration> <session-factory> <!--方言 --> <property name="dialect"> org.hibernate.dialect.Oracle9Dialect </property> <!--数据库URL --> <property name="connection.url"> jdbc:oracle:thin:@localhost:1521:orcl </property> <!--数据库访问的用户名 --> <property name="connection.username">accp</property> <!--数据库访问的用户名的密码 --> <property name="connection.password">accp</property> <!--数据库驱动这里是oracle数据库的 --> <property name="connection.driver_class"> oracle.jdbc.OracleDriver </property> <property name="myeclipse.connection.profile">oracle</property> <!--是否显示执行的SQL语句 --> <property name="show_sql">true</property> <!--是否使用数据库外连接 --> <property name="hibernate.use_outer_join">true</property> <!--事务管理类型 --> <property name="hibernate.transaction.factory_class"> net.sf.hibernate.transaction.JDBCTransactionFactory </property> <!--映射文件配置 --> <mapping resource="com/pb/entity/Login.hbm.xml" /> </session-factory> </hibernate-configuration>
在Hibernate中的对象关系映射就是把实体类与数据库中的表相对应,实现实体类中的属性与数据库表中的字段一一对应
映射是按照持久化类(实体类)的定义一创建的,而非表的定义。
配置文件可以手动写,也可以使用工具生成 如:MyEclipse生成实体类时,可以自动生成配置文件
配置文件名字:类名.hbm.xml
<?xml version='1.0' encoding='utf-8'?> <!-- 这里与hibernate.cfg.xml配置文件不一样注意 --> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!-- 这里与hibernate.cfg.xml配置文件不一样注意 --> <hibernate-mapping> <!--类名和数据库中的表名相对应 哪个用户 --> <class name="com.pb.entity.Login" table="LOGIN" schema="accp"> <!-- id代表主键 column列表 type代表数据类型--> <!-- 类中的属性 --> <id name="username" type="java.lang.String"> <!-- 表中哪一个字段或者是列名 --> <column name="USERNAME" length="20" /> <!--生成的方式 assigned代表由外部外部程序负责生成,在 save() 之前必须指定一个--> <!-- native由hibernate根据使用的数据库自行判断采用identity、hilo、sequence其中一种作为主键生成方式,灵活性很强。如果能支持identity则使用identity,如果支持sequence则使用sequence。--> <generator class="assigned" /> </id> <!-- 密码段设置 --> <!--类中的名字和数据类型 --> <property name="password" type="java.lang.String"> <!-- 表中的字段名,长度可心不要,是不为空true为不能为空,false是可以为空 --> <column name="PASSWORD" length="20" not-null="true"/> </property> <!--如果还有其它的属性,设置方式与password一样设置 --> </class> </hibernate-mapping>
(1)hibernate.dialect 指定方言后,Hibernate 可以根据低层数据库自动产生优化过的SQL。取值为org.hibenate.dialect.Dialect 的继承类。多数情况下,Hibernate
可以根据低层JDBC 返回的metadata 来判断。
(2)hibernate.show_sql 打印所有的SQL 语句到控制台,可以通过设置org.hibernate.SQL 类的日志策略到DEBUG 级,实现同样的效果。取值true|false。
(3)hibernate.format_sql 格式化SQL 语句在打印到控制台或写入日志文件时。取值true|false。
(4)hibernate.default_schema 在产生SQL 语句时,在表名前加上映射文件给出的表空间(tablespace)或数据库模式(schema)。取值SCHEMA_NAME。
(5)hibernate.default_catalog 在产生SQL 语句时,在表名前加上映射文件给出的catalog。取值CATALOG_NAME。
(6)hibernate.session_factory_name Hibernate 创建org.hibernate.SessionFactory实例后后会自动的将这个绑定到JNDI 中的名字上。取值jndi/sf。
(7)hibernate.max_fetch_depth 设置对单个表的外连接数最大深度。0是屏蔽默认的外连接设置。推荐设置为0到3之间。
(8)hibernate.default_batch_fetch_size 设置Hibernate 批量联合查询的尺度。强烈建议。推荐设置为4、8、16。
(9)hibernate.default_entity_mode 默认的实体表现模式,通过SessionFactory打开的所有的Session。取值,dynamic-map、dom4j、pojo。
(10)hibernate.order_updates 强迫Hibernate 通过被更新项的主键值排序SQL更新。这样可以在高并发时,减少事务死锁。取值true|false。
(11)hibernate.generate_statistics 如果设置为true,Hibernate 将为性能调整,收集统计信息。取值true|false。
(12)hibernate.use_identifier_rollback 如果设置为true,产生的标识属性将被重置成默认值,当对象被删除后。取值为true|false。
(13)hibernate.use_sql_comments 如果设置为true,Hiberante 将为SQL 产生注释,这样更利于调试。默认值为 false。取值为true|false。
( 1 ) hibernate.jdbc.fetch_size 指定JDBC 的查询尺度。通过调用(Statement.setFetchSize())。
(2)hibernate.jdbc.batch_size 指定Hibernate 如何使用JDBC2批量更新。取值,推荐5到30。
(3)hibernate.jdbc.batch_versioned_data 设置这个属性为true,JDBC 将返回executeBatch 执行后正确的行数。打开这个参数,通常是安全的。Hibernate 将自动
的译码这些数据使用批量DML。默认为false。取值true|false。
(4)hibernate.jdbc.factory_class 选择一个定制的org.hibernate.jdbc.Batcher。所有的应用程序不需要配置这个属性。取值,定义工厂的类名。
(5)hibernate.jdbc.use_scrollable_resultset Hibernate 使用JDBC2的可滚动记录集。当使用用户提供的JDBC 连接时,需要设置这个参数。否则,Hibernate 使用连
接MetaData。取值true|false。
(6)hibernate.jdbc.use_streams_for_binary 当读或写二进制数据或序列化数据从JDBC 或到JDBC,使用流。系统级的数据。设置true|false。
( 7 ) hibernate.jdbc.use_get_generated_keys 在插入后,可以使用JDBC3的PreparedStatement.getGeneratedKeys()中的值找回本地产生的键值。要求JDBC3+和
JRE1.4+,如果使用Hibernate identifier generator 后你的驱动程序有问题,请设置为false。默认情况下,设法连接MetaData 来决定。取值,true|false。
(8)hibernate.connection.provider_class 实现了:org.hibernate.connection.ConnectionProvider 接口的类的名称,为Hibernate 提供连接。
( 9 ) hibernate.connection.isolation 设置JDBC 事务隔离的级别。检查java.sql.Connection 的定义的常量值,但要注意大多数数据库不支持所有的隔离级别、一些附加的和非标准的隔离级别。取值,1、2、4、8。
(10)hibernate.connection.autocommit JDBC 共享连接的自动提交。(不推荐)取值,true|false。
(11)hibernate.connection.release_mode 指定什么时候,Hibernate 应该释放JDBC 连接。默认情况下,JDBC 是一直存在,只到Session 是被明确关闭或断开连
接时。对于应用的服务器JTA 数据源,你应该使用after_statement 强制释放JDBC连接在每个JDBC 请求结束后。对于非JTA 数据源,通常是在每个事务结束后释放
JDBC 连接是有意义的。将该值设为auto 时,JTA 和CMT 事务策略时,是选择after_statement 方式。JDBC 事务策略时,是选择after_transaction。取值,auto(default),
on_close,after_statment,after_transaction。注意:这个设置只影响通过 SessionFactory.openSession 打开的session。对于通
过SessionFactory.getCurrentSession 获取的session,CurrentSessionContext 实现类的配置是用来控制这些session 的连接释放模式。
(12)hibernate.connection. 传递这些属性到DriverManager.getConnection 中。
(13)hibernate.jndi. 传递这些属性到JNDI InitialContextFactory。
(1)hibernate.cache.provider_class 定制的CacheProvider 的类名。
(2)hibernate.cache.use_minimal_puts 花费更多的读操作,来优化二级缓存的最少写操作。这个操作对于集群缓存是非常有用的。在Hibernate3中,对于集群缓
存是默认开启该功能的。取值,true|false。
(3)hibernate.cache.use_query_cache 开启查询缓存,个别查询肯定应该开启查询缓存。取值,true|false。
(4)hibernate.cache.use_second_level_cache 也许过去习惯于完全屏蔽掉二级缓存,默认是开启,对于指定CacheProvider 实现类的情况。取值,true|false。
(5)hibernate.cache.query_cache_factory 实现QueryCache 接口的类名,默认是内置的StandardQueryCache
(6)hibernate.cache.region_prefix 对于使用二级缓存区域名的前缀。
(7)hibernate.cache.use_structured_entries 强迫Hibernate 在存储数据到二级缓存时,使用更人性化的格式。取值,true|false。
( 1 ) hibernate.transaction.transaction_class 使用Hibernate 事务APIs 的TransactionFactory 的类名。默认是JDBCTransactionFactory。
(2)jta.UserTransaction JTATransactionFactory 使用JNDI 名字从应用服务器中获取JTA UserTransaction。取值,jndi/ut。
(3)hibernate.transaction.manager_lookup_class是一个TransactionManagerLookup 实现类的类名。当JVM 级别的缓存开启时或在JTA 环境中使用hilo generator 时,要求指定该值。
(4)hibernate.transaction.flush_before_completion 如果设为true,session 将在事务完成阶段之前,自动将缓存区的值推入到数据库中。内置和自动session 上下文管理是被优先选用的。取值,true|false。
(5)hibernate.transaction.auto_close_session 如果设为true,session 将在事务完成之后,自动的关闭session。内置和自动session 上下文管理是被优先选用的。取
值,true|false。
(1)hibernate.current_session_context_class 提供一个对于当前session 生命周期的策略。取值,jta、thread、managed、定制类名。
( 2 ) hibernate.query.factory_class 选择HSQL 的解析实现类。取值,org.hibernate.hsql.ast.ASTQueryTranslatorFactory 和
org.hibernate.hsql.classic.ClassicQueryTranslatorFactory。
(3)hibernate.query.subsitutions Hibernate 中标记符到SQL 中标记符的映射。举例说,可以是函数名或普通字符串名。取值,如hsqLiteral=SQL_LITERAL,
hqlFunction=SQLFUN。
(4)hibernate.hbm2ddl.auto 当SessionFactory 被创建时,自动的验证或输出模式DDL(也就建表语句)到数据库中。也就是说,自动的验证数据库表结构或先删
除再重新建立,或在原表结构上更新数据表结构。当将值置为create-drop 时,在SessionFactory 被清除时,将删除数据库中表结构。取值,validate、create、update、
create-drop。
(5)hibernate.cglib.use_reflection_optimizer 用CGLIB 代替运行期的reflection(系统级属性)。在有故障时,反射是非常有用的,注意Hibernate 总是需要CGLIB,
甚至在你关闭优化后。你不可以设置这个属性在hibernate.cfg.xml 文件中。