文档章节

Hibernate 关键字Key的自动生成

ThinkGem
 ThinkGem
发布于 2016/07/17 16:50
字数 1138
阅读 40
收藏 0

Id Generator 标识符生成器 描述

increment         适用于代理主键。由Hibernate自动以递增方式生成
identity          适用于代理主键。由底层数据库生成标识符
sequence          适用于代理主键。Hibernate根据底层数据库的序列生成标识符,这要求底层数据库支持序列
hilo              适用于代理主键。Hibernate分局high/low算法生成标识符
seqhilo           适用于代理主键。使用一个高/低位算法来高效的生成long,short或者int类型的标识符。
native            适用于代理主键。根据底层数据库对自动生成标识符的方式,自动选择identity、sequence或hilo
uuid.hex          适用于代理主键。Hibernate基于128 位UUID 算法生成16 进制数值(编码后以长度32 的字符串表示)
uuid.string       适用于代理主键。与uuid.hex 类似,只是生成的主键未进行编码(以长度16 的字符串表示),不能应用

在 PostgreSQL 数据库中
assigned          适用于自然主键。由Java应用程序负责生成标识符
foreign           适用于代理主键。使用另外一个相关联的对象的标识符

以下举例:

1、指定参数的情况:
<id name="id" unsaved-value="0">
    <generator class="sequence">
        <param name="sequence">SEQ_CHILD</param>
    </generator>
</id>
使用的是sequence,适合oracle数据库;

2、对于sql server2000中的数据库子增字段,在配置文件使用下列方法实现:
<id name="id" type="long" unsaved-value="0">
     <column name="id" sql-type="numeric" not-null="true" />
     <generator class="identity" />
</id>
这里主要是:identity:代表由sql server2000数据库自己提供子增字段.如果要hibernate自己提供,则用increment关键字来实现

3、如果表中的主键用字符串类型:可以用hibernate自己提供的方法实现主键唯一:
  <id name="id" type="string" unsaved-value="null">
      <column name="cid" sql-type="char(32)" not-null="true" />
      <generator class="uuid.hex" />
  </id>
使用的是uuid.hex: 采用128位的算法来生成一个32位字符串。最通用的一种方式。适用于所有数据库。

重要的知识点:

1. 如果有部门表,有员工表,员工表中有dep_id,则表部门类和员工类是one-to-many的关系:
   可以使用:  ( 在部门类department中使用下列)
   Department类:
     /**  部门的所有员工   */
    private Set staffs = new TreeSet();
   
    xml的文件:
      <set name="staffs" >
          <key column="dep_id"/>
          <one-to-many class="hbp.sys.data.Staff"/>
      </set>
    如果是list,需要用索引<index> </index>,具体其中的含义,不是很明白.待以后研究
     
2. 如果部门要有一个负责人,即部门表(tb_department)中有一个字段:staff_id.
     那么表示部门和负责人之间的关系是many-to-one的关系
     Department类:
      /** 部门负责人id */
    private Staff staff;
   
    xml 文件
     <many-to-one name="staff" class="hbp.sys.data.Staff"  column="staff_id"/>
 
3. 多对多关系,一般我们是做一个中间关联表.我用角色和权限做了个例子,
      Right(id,name)     Role(id,name)   中间表:tb_role_right(role_id,right_id)
      Right类中有一个Role的集合:private Set roles=new TreeSet();
      Role类中也有一个Right的集合:private Set rights=new TreeSet();
      则两者是明显的多对多关系.使用many-to-many来实现;
      xml文件中
      right.hbm.xml:如下:
        <set name="roles" table="tb_role_right" cascade="all">
           <key column="right_id"/>
           <many-to-many column="role_id" class="hbp.sys.data.Role"/>
        </set>
      role.hbm.xml文件中类似:
        <set name="rights" table="tb_role_right" cascade="all">
          <key column="role_id"/>
          <many-to-many column="right_id" class="hbp.sys.data.Right"/>
        </set>

4. 几个值得注意的问题:
   a)在xml?映射文件中,写类的名字时一定用类的全名:即:包+类名如:(hbp.sys.data.Staff),这个错误使我费了半天劲.:(
   b)我在写实现基本DAO操作时,写了session.delete("from Right as right where right.id="+id); 程序死活报错,我折腾了半天,跟踪到底,才恍然大悟,hibernate在解析sql语句的时候把其中的right,当成了数据库中的右连接("保留 字"),唉,这种关键字,不能随便用啊,:)

5. hibernate中HQL语言的查询根据你的sql的不同而返回不同的对象类型.  如果你使用session.find(String hql)一般会返回一个List,如:from Staff staff;返回的是包含所有的员工对象的集合如你的hql为:select count(*) from Staff staff;则返回的是一个Integer对象如果你使用的hql为:select count(distinct staff.name),count(*) from Staff staff;则返回的是一个Object即Object[],需要先把他转换成Object[],然后在取[0],[1].这种设计我不知道 hibernate是如何处理的,感觉既好也不好.好的是可以使用一个find获得任意查询不好在于根据hql来处理返回结果,容易出错.

本文转载自:http://thinkgem.iteye.com/blog/726983

共有 人打赏支持
ThinkGem

ThinkGem

粉丝 1058
博文 138
码字总数 24109
作品 2
济南
架构师
私信 提问
SSH2框架整合常见错误整理【不断更新中】

又一个问题1、 当在几种框架集成的时候,在调用HibernateDaoSupport中的某个方法时会出现: java.lang.NoSuchMethodError: antlr.collections.AST.getLine()I 的错误。这是因为在struts2自带...

挨踢人生
2012/03/10
0
0
Hibernate——对象/数据库映射

关系数据库学最重要的一个理论就是:不要给关键字赋予任何业务意义。因为只要赋予了业务意义,就有可能发生改变,将会为以后的数据库维护造成非常大的开销。 1、hibernate应用步骤 在java应用...

java-苦苦甜甜
2012/10/17
0
0
hibernate hbm2ddl.auto 问题

<property name="hibernate.show_sql" value="true" /> <property name="hibernate.hbm2ddl.auto" value="create" /> validate 加载hibernate时,验证创建数据库表结构 create 每次加载hiber......

大凡人
2013/11/13
0
0
JAVA持久层框架的概述(ibatis>>mybatis)

现在主流的ORM映射框架有Hibernate、Apache OJB;这些基于Java的持久层框架都提供了全自动的对象–关系映射机制,能很好的实现从对象到关系数据的持久化操作。几乎不需要写任何的SQL语句(根据...

battier
2011/06/21
0
2
Bex5自动编号相关函数和用法

本文中引用的技巧来自于wex5.com(http://bbs.wex5.com/forum.php?mod=viewthread&tid=39632&extra=page%3D1)论坛, 虽然时间有些老,但是非常实用。COPY如下: 1、X5为自动编号提供了一...

朱先忠老师
2017/02/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

我是如何将博客转成PDF的

前言 只有光头才能变强 之前有读者问过我:“3y你的博客有没有电子版的呀?我想要份电子版的”。我说:“没有啊,我没有弄过电子版的,我这边有个文章导航页面,你可以去文章导航去找来看呀”...

Java3y
4分钟前
0
0
nginx的一些总结

Linux下安装Nginx完整教程及常见错误解决方案 1.Nginx安装环境 Nginx是C语言开发,建议在linux上运行,本教程使用Centos7.0作为安装环境. 1)gcc 安装nginx需要先将官网下载的源码进行编译,编译...

Yao--靠自己
11分钟前
0
0
Predicate函数式接口

Predicate接口主要用于流的筛选,比如在filter方法中传入Predicate判断。 作为函数式接口,这里居然有三个default方法,一个static方法,子孙满堂! 正统的接口方法,就是boolean test(T t)...

woshixin
12分钟前
0
0
sql 开窗函数

开窗函数:在开窗函数出现之前存在着很多用 SQL 语句很难解决的问题,很多都要通过复杂的相关子查询或者存储过程来完成。为了解决这些问题,在 2003 年 ISO SQL 标准加入了开窗函数,开窗函数...

hblt-j
23分钟前
1
0
使用Vue动态生成form表单的实例代码

具有数据收集、校验和提交功能的表单生成器,包含复选框、单选框、输入框、下拉选择框等元素以及,省市区三级联动,时间选择,日期选择,颜色选择,文件/图片上传功能,支持事件扩展。 欢迎大家s...

嫣然丫丫丫
30分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部