温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

在hibernate如何使用seqence的主键生成策略

发布时间:2021-12-06 09:11:23 来源:亿速云 阅读:192 作者:小新 栏目:编程语言

这篇文章将为大家详细讲解有关在hibernate如何使用seqence的主键生成策略,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

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

Xml代码:

<id column="MY_ID">     <generator class="sequence">      <param name="sequence">MY_SEQUENCEparam>      <param name="parameters">        START WITH 1 INCREMENT BY 1       param>     generator>    <id>    <id column="MY_ID">  <generator class="sequence">   <param name="sequence">MY_SEQUENCEparam>   <param name="parameters">     START WITH 1 INCREMENT BY 1    param>  generator> <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代码:

<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代码:

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

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

Xml代码:

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

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

Xml代码:

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

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

Xml代码:

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

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

Xml代码 :

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

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

Xml代码:

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

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

Xml代码:

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

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

Xml代码:

<property generated="always"

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

initial_price number(10, 2) default '1'

Xml代码:

<property name="initial_price">     <column name="initial_price"   default="1" generated="insert"/>    property>

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

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

Xml代码:

<class name="Hello">     <component name="Address">      <property name="">     <component>    class>

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

关于“在hibernate如何使用seqence的主键生成策略”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI