多对多关联

多对多关联关系

多对多关联关系的建立需要借助第三个表来存储多对多关联关系信息的表。
在介绍这个关系前先介绍一个小案例,前一阵子web2.0星期的时候,也流行一个应用,就是一般blog或者信息分类网站常用的一个技术——Tag。在下面的例子里我也将建立一个Tag应用。
在写博客的时候,我们的文章并不一定只属于一种分类,比如我写了一篇文章吧,就拿现在这个为例,我可以说它是属于DataBase类的,一可以说是说与Hibernate类的,所以,我就将这篇文章放进这两个分类里面。
这样就有一种新的分类形式,对于分类与文章来说就是一个多对多的关系了。

首先将我的Message类分个类,建立一个tag类,MsgTag
public class MsgTag {
    private int tagId;
    private String tagName;
private Set msgs;

Message也要做点修改,那就是加上一个存放Tag类的属性:
public class Message {
    private int msgId;
    private String ttl;
    private String desc;
    private Date date;
    private UserInfo user;   
private Set tags;
 
建立数据库相关的表:
CREATE TABLE msgTag(
  `tag_id` int(11) NOT NULL auto_increment,
  `tag_name` char(20) NOT NULL default 0,
  PRIMARY KEY  (`tag_id`)
) ENGINE=InnoDB DEFAULT CHARSET=UTF8;

CREATE TABLE `msg_tag_role` (
  `msg_id` int(11) NOT NULL ,
  `tag_id` int(11) NOT NULL ,
  PRIMARY KEY  (`msg_id`,`tag_id`)
) ENGINE=InnoDB DEFAULT CHARSET=UTF8;

其中msg_tag_role 用来存放message与tag关联关系的表。
在做多对多关系的配置中<many-to-many>节点很重要,基本两个表的应射文件都要用到这个节点。
先在Message.hbm.xml这个文件里加一个节点:
      <set name="grps" table="msg_tag_role" cascade="save-update" fetch="join">
         <key column="msg_id"/>
        <many-to-many class="xiaojin.hibernate.entity.MsgTag" column="tag_id"></many-to-many>
       </set>
同时MsgTag.hbm.xml文件:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class name="xiaojin.hibernate.entity.MsgTag" table="msgtag" >
        <id name="tagId" type="java.lang.Integer">
            <column name="tag_id" />
            <generator class="native"></generator>
        </id>
        <property name="tagName" type="java.lang.String">
            <column name="tag_name" />
        </property>
        <set name="msgs" table="msg_tag_role" cascade="save-update" inverse="false">
          <key column="tag_id"/>           
          <many-to-many class="xiaojin.hibernate.entity.Message" column="msg_id"></many-to-many>
        </set>
    </class>
</hibernate-mapping>
这样我们的多对多关系就建立起来了,可以看到,该关系的建立完全都是表msg_tag_role 起的作用。
测试方法:
    public static void saveMsgAndTag(){
        MsgTag tag1 = new MsgTag();
        tag1.setTagName("yule");
        MsgTag tag2 = new MsgTag();
        tag2.setTagName("jingji");
        Set grps = new HashSet<MsgTag>();
        grps.add(tag1);
        grps.add(tag2);
        Message msg1 = new Message();
        msg1.setTtl("yule_msg1");
        msg1.setDesc("desc");
        msg1.setTags(grps);
        Message msg2 = new Message();
        msg2.setTtl("yule_msg2");
        msg2.setDesc("desc");
        msg1.setTags(grps);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值