Hibernate实战(第2版)读书笔记

开发 后端
本文是作者认真学习Hibernate作下的笔记,参考的书籍是Hibernate实战(第2版)。

最近时间重读hibernate实战(第2版),哈哈,很长时间不用几乎都忘完了。现在作为读书笔记记录下来,以供自己和别人参考。部分例子摘自hibernate实战(第2版)书中。本人能力有限,难免出现错误的地方,欢迎指正。

在hibernate使用seqence的主键生成策略时候,要这样写(下面的写法是针对HSQLDB,不清楚在其他数据库也通用)

Xml代码:

  1. <id column="MY_ID">    
  2.  <generator class="sequence">    
  3.   <param name="sequence">MY_SEQUENCEparam>    
  4.   <param name="parameters">    
  5.     START WITH 1 INCREMENT BY 1     
  6.   param>    
  7.  generator>    
  8. <id>    
  9. <id column="MY_ID"> 
  10.  <generator class="sequence"> 
  11.   <param name="sequence">MY_SEQUENCEparam> 
  12.   <param name="parameters"> 
  13.     START WITH 1 INCREMENT BY 1  
  14.   param> 
  15.  generator> 
  16. <id>  

hibernate实战(第2版)书中是这样写的 INCREMENT 1 START WITH 1,这样写插入的call next value for MY_SEQUENCE 返回的是0,START WITH 1 INCREMENT BY 1 执行call next value for MY_SEQUENCE返回的是1,这样奇怪的问题,难道是hsqldb有bug?我也没有去做过多的深究。

Xml代码:

  1. <class dynamic-insert="true" dynamic-update="true">   

dynamic-insert 属性告诉hibernate是否在insert语句中包含空的属性值(设置为true,是表明在insert语句中不包含为null的属性,也就是insert语句中包含的属性必须是非空的字段)。

这两个属性在某些地方会有用,比如说在更新中设置dynamic-update=true,如果你仅仅更新了一个属性,没有必要把其他属性的更新也放在sql中,也提高了数据库的执行效率。但是也带来一个副作用,可能就是hibernate要进行比较每个属性的值,来决定是否在sql语句中包含这个字段。当然这对 字段比较多的类是比较有用的。dynamic-insert在做insert操作时候,也是如此。

Xml代码:

  1. <hibernate-mapping default-access="field">    
  2. <class mutable="false">   

标记这个类为不可变类。这样hibernate就可以避免做脏检查。为了保持这个不可变属性,***不写set方法,仅仅保留get方法。设置值通过构造来设置。还要明确指示hibernate访问这个类的字段要通过field来访问,而不是通过get-set方法,这个由 hibernate-mapping的 default-access="field"来设置。

Xml代码:

  1. <hibernate-mapping auto-import="false">    
  2.  <import class="mypackage.Class" rename="Hello" />    
  3. hibernate-mapping>   

一般情况下,你写一个类的映射后,hibernate 会自动的导入到HQL的命名空间中。你在HQL查询时候可以仅仅通过类名,而不是包名.类名来使用指定的类了。但是,存在这样一种情况,如果在不同包中有相同的类名,在HQL中就会引起歧义,不过一个很好的办法就是在hibernate-mapping中关闭自动导入的属性,采取显式导入,然后重命名之。这样,你在HQL中就可以直接写 from Hello,而避免了歧义。

Xml代码:

  1. <hibernate-mapping package="mypackage.model">   

定义package这个属性,可以在这个映射文件中给所有未以包名开头的类名加上定义的包作为前缀。

Xml代码:

  1. <property name="description" column="`description`">   

之所以加反引号,是因为你觉得可能description在特定的数据库中是关键字。你加上反引号后,hibernate会为你针对不同的数据库做特定的转化。例如sqlserver,hibernate会为你加上[description],mysql加上`description`,另外在在hsqldb中给description加反引号后,产生的是"description",这样执行起来反而会报错。

Xml代码 :

  1. <property name="description" column="desc" access="field">   

指定description字段通过field直接访问。

Xml代码:

  1. <property name="total" formula="total + tax_rate * total">   

这个公式在每次查询时候求值,并且这个属性不会被保存和更新,如果你改变其中的数据例如tax_rate,属性值不会去自动计算。

Xml代码:

  1. <property name="mydata" update="false" insert="false">   

如果update和i nsert都设置false的话,这个字段就不会出现在INSERT和UPDATE语句中。通常不再类中给不可变的属性添加公有的设置方法。

Xml代码:

  1. <property generated="always"   

generated的合法值是always和insert。这个属性通常和dynamic-insert配合起来才更有用。一般用来在属性中插入默认值。

initial_price number(10, 2) default '1'

Xml代码:

  1. <property name="initial_price">    
  2.  <column name="initial_price"   
  3. default="1" generated="insert"/>    
  4. property>   

其中的default属性,只在生成表结构时候有用。hibernate并不会在Java类中,给空的属性设置默认值。

在插入有default属性的字段中,要想使default起作用,必须设置dynamic-insert=true,这样保证有default属性的字段字段不会出现在insert中(default的字段为null),否则,它的值为null(插入NULL而不是默认值),另外默认值插入到数据库之后,因为设置了generated=always,hibernate会在插入后自动的执行一个select,给Java类中的属性设置,如果没有设置generated属性,需要显式调用session.flush()语句。

Xml代码:

  1. <class name="Hello">    
  2.  <component name="Address">    
  3.   <property name="">    
  4.  <component>    
  5. class>   

如果component中说有的属性都为null,那么查询时候,这个组件个引用是null,就是说hello.getAddress()返回的是null,只要有至少一个不为null,那么返回这个组件的引用将不是null。

【编辑推荐】

  1. 初学者适用的Hibernate学习方法
  2. Hibernate优化方法解析
  3. Hibernate一对多关系的处理
  4. Struts与Hibernate的***结合方案
  5. Hibernate的性能优化

 

责任编辑:仲衡 来源: JavaEye技术网站
相关推荐

2009-06-18 14:20:45

hibernate实战

2016-11-16 09:52:39

Linux读书笔记内核

2015-03-10 14:05:46

程序员软件架构读书笔记

2017-02-07 15:54:14

数据可视化数据分析

2015-07-15 13:45:51

SQLServer读书笔记

2015-07-15 13:48:01

SQLServer读书笔记

2021-01-04 18:21:47

AI

2020-12-24 17:40:00

MySQL角色管理数据库

2014-04-16 11:39:52

2013-07-22 11:25:12

2021-09-23 14:39:28

鸿蒙HarmonyOS应用

2015-06-19 07:50:47

2020-12-24 18:00:45

MySQL元数据锁数据库

2009-08-26 17:22:09

C#语言

2009-08-25 16:32:24

C#语言

2009-06-16 15:52:18

Hibernate文档

2009-09-29 17:22:30

Hibernate S

2009-06-16 15:32:24

Hibernate文档

2009-06-16 15:42:44

Hibernate文档

2009-06-18 11:25:26

Hibernate L
点赞
收藏

51CTO技术栈公众号