细说Hibernate配置文件

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更为方便。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容