MySQL版数据库表结构

 
DROP TABLE IF EXISTS SYS_DICT_ITEM;
CREATE TABLE SYS_DICT_ITEM(
ITEM_CODE VARCHAR(100) NOT NULL,
ITEM_VALUE VARCHAR(200),
DICT_CODE VARCHAR(100) NOT NULL,
PARENT_CODE VARCHAR(100),
EDIT_TIME DATETIME,
ITEM_DESC VARCHAR(100),
SEQ INT(6),
STATUS CHAR(1),
PRIMARY KEY(DICT_CODE, ITEM_CODE)
);

其中,PARENT_CODE字段即表示SYS_DICT_ITEM表的ITEM_CODE字段

先来看看XML方式的Hibernate映射关系

JavaBean类如下,简单起见,setter和getter方法省略了

public class DictItem extends StatefulBean {
private static final long serialVersionUID = -377812468484463777L;
private String code; // 字典项编码
private String value; // 字典项值
private String dictCode; // 字典编码
private String parentCode; // 父节点编码
private Date editTime; // 修改时间
private String desc; // 描述
private Integer seq = 0; // 序号:0(默认值)
private Boolean status = Boolean.valueOf(true); // 可用状态:true-启用(默认值),false-停用
private Set<DictItem> children;
}

Hibernate的XML映射文件如下:

<class name="DictItem" table="SYS_DICT_ITEM">
<id name="code" type="java.lang.String">
<column name="item_code"></column>
<generator class="assigned"></generator>
</id>
<property name="value" type="java.lang.String">
<column name="item_value"></column>
</property>
<property name="dictCode" type="java.lang.String">
<column name="dict_code"></column>
</property>
<property name="parentCode" type="java.lang.String">
<column name="parent_code"></column>
</property>
<property name="editTime" type="java.util.Date">
<column name="edit_time"></column>
</property>
<property name="desc" type="java.lang.String">
<column name="item_desc"></column>
</property>
<property name="seq" type="java.lang.Integer">
<column name="seq"></column>
</property>
<property name="status" type="java.lang.Boolean">
<column name="status"></column>
</property> <!-- DictItem:DictItem = 基于外键的单向1:n关联-->
<set name="children" inverse="false" cascade="all" lazy="false" order-by="seq">
<key column="parent_code"/>
<one-to-many class="DictItem"/>
</set>
</class>

换成注解方式的JavaBean代码如下:

@Entity
@Table(name="SYS_DICT_ITEM")
public class DictItem extends StatefulBean {
private static final long serialVersionUID = -377812468484463777L;
@Id
@GenericGenerator(name = "idGenerator", strategy = "assigned")
@Column(name="ITEM_CODE")
private String code; // 字典项编码 @Column(name="ITEM_VALUE")
private String value; // 字典项值 @Column(name="DICT_CODE")
private String dictCode; // 字典编码 @Column(name="PARENT_CODE")
private String parentCode; //父项编码 @Column(name="EDIT_TIME")
private Date editTime; // 修改时间 @Column(name="ITEM_DESC")
private String desc; // 描述 @Column(name="SEQ")
private Integer seq; // 序号 @Column(name="STATUS")
private Boolean status = Boolean.valueOf(true); // 可用状态:true-启用(默认值),false-停用 @OneToMany(targetEntity=DictItem.class, mappedBy="children", cascade=CascadeType.ALL, fetch = FetchType.EAGER)
@JoinColumn(name = "PARENT_CODE")
@OrderBy("seq")
private Set<DictItem> children;
}

这里也有一篇帖子是使用注解方式的,但是父对象类型是自定义的JavaBean,而不是简单的Java类型

http://guobin6125.iteye.com/blog/1597937

由于系统中需要将查询出来的JavaBean对象转换成json字符串,使用json-lib,父对象如果类型使用自定义的JavaBean,即DictItem类本身,转换成json字符串的时候就会报错,提示转换出现循环xxx,因此转换一下思路,使用String简单类型来保存关联关系即可。

关于Hibernate使用XML还是注解来维护映射关系,各有好处吧。并且,Spring框架也对Hibernate注解方式提供了很好的兼容性支持。

虽然XML内容是多了点儿,但是一般情况情况下,咱们也不会一个字符一个字符重新手写的,大部分都是拷贝过来修改的;而注解方式,虽然看起来简单,但是需要熟悉其中各种关系的配置方式,并且需要直接修改JavaBean类的代码,源码侵入性较强。

因此,选用适合的方式即可。

转自:http://www.cnblogs.com/wenlong/p/4070096.html

Hibernate注解方式一对多自关联关系映射的更多相关文章

  1. Hibernate注解(二):关联关系映射注解

    关联关系映射注解以下项目均在之前相应代码的基础上进行的修改.这些项目均需要做的是: 删除映射文件 在hibernate.cfg.xml中注册实体类 注解的重要位置在实体类中关联属性上.这里是关联 ...

  2. hibernate注解方式来处理映射关系

    在hibernate中,通常配置对象关系映射关系有两种,一种是基于xml的方式,另一种是基于annotation的注解方式,熟话说,萝卜青菜,可有所爱,每个人都有自己喜欢的配置方式,我在试了这两种方式 ...

  3. Hibernate 注解方式配置

    在Hibernate3之后就可以使用注解的方式去配置.而且在工作中我们使用的更多的也是注解方式去配置项目,所以还有一部分使用配置文件去配置的一些关系就不在此去一一举例,需要了解的朋友可以去查看Hibe ...

  4. hibernate之关于一对多单向关联映射

    [hibernate]之关于一对多单向关联映射 基于外键的一对多关联映射! 一对多,Group(组)对于Person(人),一个组能够有多个人!ok? Hibernate主要有两种配置方法.一种是An ...

  5. Hibernate注解方式配置-继承关系

    在JPA中,实体继承关系的映射策略共有三种:单表继承策略(table per class).Joined策略(table per subclass)和Table_PER_Class策略. 1.单表继承 ...

  6. Hibernate注解:一对多外键关联

    情形:两个表,cms_mode是主表,cms_model_field是子表,cms_model_field的model_id字段关联到cms_model的主键. # # Source for tabl ...

  7. 基于已构建S2SH项目配置全注解方式简化配置文件

    如果还不熟悉s2sh项目搭建的朋友可以先阅读 eclipse环境下基于tomcat-7.0.82构建struts2项目 eclipse环境下基于已构建struts2项目整合spring+hiberna ...

  8. Hibernate(6)—— 一对多 和 多对多关联关系映射(xml和注解)总结

    俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及的知识点总结如下: One to Many 映射关系 多对一单向外键关联(XML/Annotation) 一对多单向外键关联(XM ...

  9. Hibernate—— 一对多 和 多对多关联关系映射(xml和注解)总结(转载)

    One to Many 映射关系 多对一单向外键关联(XML/Annotation) 一对多单向外键关联(XML/Annotation) 懒加载和积极加载 一对多双向外键关联(XML/Annotati ...

随机推荐

  1. [golang] Glide 包管理

    一.概述 golang的包管理工具有很多,本篇幅主要介绍glide进行包管理. 二.安装及命令介绍 go get github.com/Masterminds/glide glide create|i ...

  2. Ubuntu 14.04 静态IP设置, ping通win7

    ubuntu 14.04以后不支持 /etc/init.d/networing restart命令,使用ifdown et0 和ifup eth0 使用echo $?查看上一次命令执行的结果 ifdo ...

  3. Spring 注解@Component,@Service,@Controller,@Repository

    Spring 注解@Component,@Service,@Controller,@RepositorySpring 2.5 中除了提供 @Component 注释外,还定义了几个拥有特殊语义的注释, ...

  4. jQuery页面引导插件 jquery-pagewalkthrough

    http://jwarby.github.io/jquery-pagewalkthrough/ 源码 https://github.com/jwarby/jquery-pagewalkthrough

  5. U盘启动ubuntu 12.04

    第一步: 下载U盘启动制作工具Universal-USB-Installer-1.9.5.9.exe http://www.pendrivelinux.com/downloads/Universal- ...

  6. python之celery使用详解一

    前段时间需要使用rabbitmq做写缓存,一直使用pika+rabbitmq的组合,pika这个模块虽然可以很直观地操作rabbitmq,但是官方给的例子太简单,对其底层原理了解又不是很深,遇到很多坑 ...

  7. 什么是UML?分哪两类?

    统一建模语言(UML是 Unified Modeling Language的缩写)是用来对软件密集系统进行可视化建模的一种语言.UML为面向对象开发系统的产品进行说明.可视化.和编制文档的一种标准语言 ...

  8. iOS按钮的基本使用代码优化

    将图片按钮进行连线, 声明方法同时连接六个按钮 -(void)move:(UIButton *)btn{ //    NSLog(@"看见一个美女"); //头尾式动画 //0.开 ...

  9. ImportError: cannot import name 'main'的解决办法

    一.现象 使用pip出现如下提示: Traceback (most recent call last): File "/usr/bin/pip3", line 9, in < ...

  10. 取出csv文件中的中文评论数据

    # -*- coding: utf-8 -*- import csv import re csvfile = 'weibo.csv' def columns_data(path, column): c ...