Hibernate配置文件主要用于配置数据库连接和Hibernate运行时所需的各种属性。
每个Hibernate配置文件对应一个Configuration对象。
Hibernate配置文件有两种格式
hibernate.properties
hibernate.cfg.xml
JDBC连接属性
connection.url:数据库URL
connection.username:数据库的用户名
connection.password:数据库的用户密码
connection.driver_class:数据库的JDBC驱动
dialect:配置数据库的方言,根据底层数据库的不同产生不同的sql语句。Hibernate会针对数据库的特性在访问时进行优化。
C3P0数据源
hibernate.c3po.max_size:数据库连接池的最大连接数。
hibernate.c3po.min_size:数据库连接池的最小连接数。
hibernate.c3po.acquire_increment:当数据库连接池的连接耗尽时,同一时刻获取多少数据库连接。
hibernate.c3po.timeout:数据库连接池中的连接对象多长时间没有使用过后,就应该被销毁。
hibernate.c3po.idle_test_period:表示连接池检测线程多长时间检测一次池内的连接对象是否超时,连接池本身不会将自己移除,而是专门有一个线程多长时间检测一次池内所有的连接对象是否超时。这个线程通过比较连接对象最后一次的使用时间和当前时间的时间差和timeout进行对比,进而决定是否销毁这个连接对象。
hibernate.c3po.max_statements:缓存Statement对象的数量。
两个重要的Hibernate配置选项
hibernate.jdbc.fetch_size:实质上是调用Statement.setFetchSize方法设定JDBC的Statement读取数据的时候每次从数据库中取出的记录数。最优值为100。
hibernate.jdbc.batch_size:设定对数据库进行批量删除,批量更新和批量添加的时候批次的大小。类似于设置缓冲区大小的意思。batchSize越大,批量操作向数据库发送的sql越少,速度就越快。最优值为30。
POJO类和hbm.xml
POJO类和关系数据库之间的映射可以用一个XML文档来定义。
通过POJO类的数据库映射文件,Hibernate可以理解为持久化类和数据表之前的对应关系,也可以理解为持久化类的属性和数据库表列之间的关系。
在运行时Hibernate将根据映射文件生成各种SQL语句。
hbm全称为Hibernate Mapping,译为Hibernate映射。
hibernate mapping属性解释:
映射对象标识符
Hibernate使用对象标识符(OID)来建立内存中的对象和数据表中记录的对应关系。对象的OID和数据表中的主键一致。Hibernate通过标识符生成器为主键赋值。
Hibernate推荐在数据表中使用代理主键,即不具备业务含义的字段。代理主键通常为整数类型。因为整数类型要比字符串类型节省更多的数据空间。
在对象-关系映射文件中,<id>元素用于设置对象标识符。<generator>用于设置标识符生成器。
Hibernate提供了标识符生成器接口:IdentifierGenerator,并提供了各种内置实现。
increment标识符生成器
increment标识符生成器由Hibernate以递增的方式为代理主键赋值。
Hibernate会先读取表中的主键的最大值,接下来向表中插入数据时,就在max(id)的基础上递增。增量为1。
适用范围:
- 由于increment生成标识符机制不依赖于底层数据库系统,因此它适用于所有的数据库系统。
- 适用于只有单个Hibernate应用进程访问访问同一个数据库的场合,在集群环境下不推荐使用它。
- OID必须为long, int或者short类型。如果将OID设为byte类型,会在运行时出现异常。
identity标识符生成器
identity标识符生成器由底层数据库来负责生成标识符,它要求底层数据库将主键设为自增长类型。
适用范围:
- 由于identity生成标识符的机制依赖于底层数据库系统,因此,要求底层数据库系统必须支持自增长字段类型。
- OID必须为long, int或者short类型。如果将OID设为byte类型,会在运行时出现异常。
sequence标识符生成器
sequence标识符生成器用底层数据库提供的序列来生成标识符。
Hibernate在持久化一个对象后,会从底层数据库的序列中获取唯一的标识号,再把它作为主键值。
hilo标识符生成器
hilo标识符生成器由Hibernate按照一种high/low算法生成标识符,它从数据库特定的表中的字段获取high值。
Hibernate在持久化一个对象时,由Hibernate负责生成主键值。hilo标识符生成器在生成标识符时,需要读取并更改HI_TABLE表中的NEXT_VALUE值。
适用范围:
- 由于hilo标识符机制不依赖于底层数据库系统,因此它适用于所有的数据库系统。
- OID必须为long, int或者short类型。如果将OID设为byte类型,会在运行时出现异常。
Native标识符生成器
Native标识符生成器依据底层数据库对自动生成标识符的支持能力,来选择使用identity,sequence或hilo标识符生成器。
适用范围:
- 由于native能够根据底层数据库的类型,自动选择合适的标识符生成器,因此很适合用于跨数据库平台开发。
- OID必须为long, int或者short类型。如果将OID设为byte类型,会在运行时出现异常。
映射Java的时间、日期类型
在Java中代表时间和日期的类型包括,java.util.Date和java.util.Calendar。此外在JDBC API中还提供了三个扩展了java.util.Date类的子类:java.sql.Date,java.sql.Time和java.sql.Timestamp,这三个类分别和标准的SQL类型中的DATE, TIME和TIMESTAMP类型对应。
在标准SQL中,DATE表示日期,TIME表示时间,TIMESTAMP表示时间戳,同时包含日期和时间信息。
由于java.util.Date是java.sql.Date,java.sql.Time和java.sql.Timestamp的父类,所以java.util.Date可以对应标准SQL中的DATE, TIME和TIMESTAMP。
所以在设置持久化类型的DATE类型是设置为java.util.Date。
如何把java.util.Date映射为Time, Date, Timestamp:
可以通过property的type属性进行映射:
<property name="date" type="timestamp">
<column name="DATE"/>
</property>
其中timestamp, time, date既不是Java类型,也不是标准的SQL类型,而是Hibernate映射类型。
Java大对象类型的Hibernate映射
在Java中可以使用java.util.String表示长字符串(长度超过255),字节数组byte[]可以用来存放图片或文件的二进制数据。此外,在JDBC的API中还提供了java.sql.Clob和java.sql.Blob类型,它们分别对应标准SQL中的Clob和Blob,Clob表示字符串大对象,Blob表示二进制对象。
MySQL不支持标准SQL的Clob类型,在MySQL中使用TEXT, MEDIUMTEXT和LONGTEXT类型表示长度超过255的长文本数据。
在持久化类中,二进制大对象可以声明为byte[]或java.sql.Blob类型,字符串类型可以声明为java.lang.String或java.sql.Clob。
实际上在Java应用程序中,处理长度超过255的字符串,使用java.lang.String比java.sql.Clob更为方便。