hibernate 映射文件属性自定义查询语句?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hibernate 映射文件属性自定义查询语句?相关的知识,希望对你有一定的参考价值。

标题可能 说得有不清不楚。
我举个例
class Student
private int sort;//考试名次
//get and set

而数据库只有分数列,所以需要自定义sql语句,为sort属性赋值
在映射文件里怎么写?

看得明白吗?
别告诉我没有的,我学过,但忘了(汗)

谢过先

参考技术A <property name="total">
<formula>
( select sum(li.quantity*p.price)
from LineItem li, Product p
where li.productId = p.productId
and li.customerId = customerId
and li.orderNumber = orderNumber )
</formula>
</property>
试试

Hibernate 对象关系映射文件

简介:

  POJO 类和关系型数据库之间的映射可以用一个 XML 文档来定义

  通过 POJO 类的数据库映射文件,Hibernate 可以理解持久化类和数据表之间的对应关系,也可以理解持久化类属性与数据库表列之间的关系

  在运行时 Hibernate 将根据这个映射文件来生成各种 SQL 语句

  映射文件的扩展名为 .hbm.xml

 

 

Hibernate-mapping:hibernate-mapping 是 映射文件的根元素

  default-cascade(默认为 none):设置hibernate默认的级联风格。若配置 Java 属性,集合映射时没有指定 cascade 属性,则 Hibernate 将采用此处指定的级联风格。

  default-access (默认为 property):指定 Hibernate 的默认的属性访问策略。默认值为 property,即使用 getter, setter 方法来访问属性。若指定 access,则 Hibernate 会忽略 getter/setter 方法,而通过反射访问成员变量。

  default-lazy(默认为 true):设置 Hibernat morning的延迟加载策略。该属性的默认值为 true,即启用延迟加载策略。若配置 Java 属性映射,集合映射时没有指定 lazy 属性,则 Hibernate 将采用此处指定的延迟加载策略

  package (可选):指定一个包前缀,如果在映射文档中没有指定全限定的类名, 就使用这个作为包名。 

class:class 元素用于指定类和表的映射

  name:指定该持久化类映射的持久化类的类名

  table:指定该持久化类映射的表名,Hibernate 默认以持久化类的类名作为表名

  dynamic-insert:若设置为 true,表示当保存一个对象时,会动态生成 insert 语句,insert 语句中仅包含所有取值不为 null 的字段,默认值为 false

  dynamic-update:若设置为 true,表示当更新一个对象时,会动态生成 update 语句,update 语句中仅包含所有取值需要更新的字段,默认值为 false

  select-before-update:设置 Hibernate 在更新某个持久化对象之前是否需要先执行一次查询。默认值为 false

  batch-size:指定根据 OID 来抓取实例时每批抓取的实例数。

  lazy:指定是否使用延迟加载.

  mutable:若设置为 true,等价于所有的 <property> 元素的 update 属性为 false,表示整个实例不能被更新。默认为 true. 

  discriminator-value:指定区分不同子类的值,当使用 <subclass/> 元素来定义持久化类的继承关系时需要使用该属性

 

映射对象标识符:

  Hibernate 使用对象标识符(OID) 来建立内存中的对象和数据库表中记录的对应关系,对象的 OID 和数据表的主键对应,Hibernate 通过标识符生成器来为主键赋值

  Hibernate 推荐在数据表中使用代理主键,即不具备业务含义的字段。代理主键通常为整数类型,因为整数类型比字符串类型要节省更多的数据库空间。

  在对象-关系映射文件中, <id> 元素用来设置对象标识符,<generator> 子元素用来设定标识符生成器。

  Hibernate 提供了标识符生成器接口:IdentifierGenerator,并提供了各种内置实现

 

  id:设定持久化类的 OID 和表的主键的映射

    name:标识持久化类 OID 的属性名 

    column:设置标识属性所映射的数据表的列名(主键字段的名字)

    unsaved-value:若设定了该属性,Hibernate 会通过比较持久化类的 OID 值和该属性值来区分当前持久化类的对象是否为临时对象

    type:指定 Hibernate 映射类型。Hibernate 映射类型是 Java 类型与 SQL 类型的桥梁。如果没有为某个属性显式设定映射类型,Hibernate 会运用反射机制先识别出持久化类的特定属性的 Java 类型,然后自动使用与之对应的默认的 Hibernate 映射类型

    Java 的基本数据类型和包装类型对应相同的 Hibernate 映射类型。基本数据类型无法表达 null,所以对于持久化类的 OID 推荐使用包装类型

    generator:设定持久化类设定标识符生成器

      class:指定使用的标识符生成器全限定类名或其缩写名

        建议设置为 native

  property:property 元素用于指定类的属性和表的字段的映射

    name:指定该持久化类的属性的名字

    column:指定与类的属性映射的表的字段名.。如果没有设置该属性,Hibernate 将直接使用类的属性名作为字段名 

    type:指定 Hibernate 映射类型. Hibernate 映射类型是 Java 类型与 SQL 类型的桥梁,如果没有为某个属性显式设定映射类型,Hibernate 会运用反射机制先识别出持久化类的特定属性的 Java 类型,然后自动使用与之对应的默认的 Hibernate 映射类型

    not-null:若该属性值为 true,表明不允许为 null,默认为 false

    access:指定 Hibernate 的默认的属性访问策略。默认值为 property,即使用 getter,setter 方法来访问属性。若指定 field,则 Hibernate 会忽略 getter/setter 方法,而通过反射访问成员变量

    unique:设置是否为该属性所映射的数据列添加唯一约束.

    index:指定一个字符串的索引名称。当系统需要 Hibernate 自动建表时,用于为该属性所映射的数据列创建索引,从而加快该数据列的查询.

    length:指定该属性所映射数据列的字段的长度

    scale:指定该属性所映射数据列的小数位数,对 double,float,decimal 等类型的数据列有效

    formula:设置一个 SQL 表达式, Hibernate 将根据它来计算出派生属性的值. 

      派生属性:并不是持久化类的所有属性都直接和表的字段匹配,持久化类的有些属性的值必须在运行时通过计算才能得出来,这种属性称为派生属性

      使用 formula 属性时,formula=“(sql)” 的英文括号不能少

      Sql 表达式中的列名和表名都应该和数据库对应,而不是和持久化对象的属性对应

      如果需要在 formula 属性中使用参数,这直接使用 where cur.id=id 形式,其中 id 就是参数,和当前持久化对象的 id 属性对应的列的 id 值将作为参数传入.


以上是关于hibernate 映射文件属性自定义查询语句?的主要内容,如果未能解决你的问题,请参考以下文章

hibernate学习二 基本用法

Hibernate 对象关系映射文件

Hibernate命名查询

HQL多表查询 ---- Hibernate之查询语句

如何使用 JPA 和 Hibernate 通过自定义对象实体属性进行查询

hibernate 中的ORM是如何与数据库实现存储和查询的