欢迎来到三一文库! | 帮助中心 三一文库31doc.com 一个上传文档投稿赚钱的网站
三一文库
全部分类
  • 研究报告>
  • 工作总结>
  • 合同范本>
  • 心得体会>
  • 工作报告>
  • 党团相关>
  • 幼儿/小学教育>
  • 高等教育>
  • 经济/贸易/财会>
  • 建筑/环境>
  • 金融/证券>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 三一文库 > 资源分类 > DOC文档下载  

    hibernate各种关联关系.doc

    • 资源ID:8938497       资源大小:100.50KB        全文页数:11页
    • 资源格式: DOC        下载积分:4
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录   微博登录  
    二维码
    微信扫一扫登录
    下载资源需要4
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    hibernate各种关联关系.doc

    一、多对一关联映射t_groupid | name 1 | 尚学堂t_userid | name | groupid1 | 菜10 | 12 | 容祖儿 | 1<many-to-one>会在多的一端加入一个外键,指向一的一端,这个外键是由<many-to-one>中的column属性定义的,如果忽略了这个属性那么默认的外键与实体的属性一致<many-to-one>标签的定义示例: * <many-to-one name="group" column="groupid"/>二、一对一主键关联1、一对一主键关联单向t_idcardid | cardNo1 | 88888888882 | 9999999999t_personid | name1 | 菜102 | 容祖儿hibernate一对一主键关联映射(单向关联Person->IdCard)一对一主键关联映射:让两个实体对象的id保持相同,这样可以避免多余的字段被创建具体映射:<id name="id"><!- person的主键来源idCard,也就是共享idCard的主键 -><generator class="foreign"><param name="property">idCard</param></generator></id><property name="name"/><!- one-to-one标签的含义,指示hibernate怎么加载它的关联对象,默认根据主键加载,constrained="true",表明当前主键上存在一个约束,person的主键作为外键参照了idCard -><one-to-one name="idCard" constrained="true"/>2、一对一主键关联双向t_idcardid | cardNo1 | 88888888882 | 9999999999t_personid | name3 | 菜104 | 容祖儿hibernate一对一主键关联映射(双向关联Person<->IdCard)需要在idcard映射文件中加入<one-to-one>标签指向person,指示hibernate如何加载person默认根据主键加载三、一对一外键关联1、一对一外键关联单向t_personid | name | idcard5 | 菜10 | 1006 | 容祖儿 | 200t_idcardid | cardNo100 | 8888888888200 | 9999999999hibernate一对一唯一外键关联映射(单向关联Person->IdCard)一对唯一外键关联映射是多对一关联映射的特例可以采用<many-to-one>标签,指定多的一端的unique=true,这样就限制了多的一端的多重性为一通过这种手段映射一对一唯一外键关联2、一对一外键关联双向t_personid | name | idcard7 | 菜10 | 1008 | 容祖儿 | 200t_idcardid | cardNo100 | 8888888888200 | 9999999999hibernate一对一唯一外键关联映射(双向关联Person<->IdCard)一对一唯一外键关联双向,需要在另一端(idcard),添加<one-to-one>标签,指示hibernate如何加载其关联对象,默认根据主键加载person,外键关联映射中,因为两个实体采用的是person的外键维护的关系,所以不能指定主键加载person,而要根据person的外键加载,所以采用如下映射方式:<one-to-one name="person" property-ref="idCard"/>四、一对多关联映射1、一对多关联映射单向t_studentid | name | classesid1 | 10 | 12 | 祖儿 | 1t_classesid | name1 | 尚学堂hihernate一对多关联映射(单向Classes->Student)一对多关联映射利用了多对一关联映射原理多对一关联映射:在多的一端加入一个外键指向一的一端,它维护的关系是多指向一一对多关联映射:在多的一端加入一个外键指向一的一端,它维护的关系是一指向多也就是说一对多和多对一的映射策略是一样的,只是站的角度不同 <set name="students"> <key column="classesid"/> <one-to-many class="Students"/> </set>在一一端维护关系的缺点:* 如果将t_student表里的classesid字段设置为非空,则无法保存* 因为不是在student这一端维护关系,所以student不知道是哪个班的, 所以需要发出多余的update语句来更新关系2、一对多关联映射双向t_studentid | name | classesid 1 | 10 | 12 | 祖儿 | 1t_classesid | name1 | 尚学堂hihernate一对多关联映射(双向Classes<->Student)一对多双向关联映射:* 在一一端的集合上使用<key>,在对方表中加入一个外键指向一一端* 在多一端采用<many-to-one>注意:<key>标签指定的外键字段必须和<many-to-one>指定的外键字段一致,否则引用字段的错误如果在”一“一端维护一对多关联关系,hibernate会发出多余的udpate语句,所以我们一般在多的一端来维护关联关系关于inverse属性:inverse主要用在一对多和多对多双向关联上,inverse可以被设置到集合标签<set>上,默认inverse为false,所以我们可以从”一“一端和”多“一端维护关联关系,如果设置成inverse为true,则我们只能从多一端来维护关联关系注意:inverse属性,只影响数据的存储,也就是持久化inverse和cascade* inverse是关联关系的控制方向* cascade操作上的连锁反应五、多对多关联关系1、多对多关联关系单向t_user_roleuserid | roleid1 | 11 | 22 | 22 | 33 | 13 | 23 | 3t_roleid | name1 | 数据录入人员2 | 商务主管 3 | 大区经理t_userid | name1 | 102 | 祖儿3 | 杰伦hibernate多对多关联映射(单向User->Role)具体映射方式:<set name="roles" table="t_user_role"><key column="userid"/><many-to-many class="com.bjsxt.hibernate.Role" column="roleid"/></set>2、多对多关联关系双向t_user_roleuserid | roleid2 | 13 | 24 | 22 | 33 | 13 | 23 | 3t_roleid | name1 | 数据录入人员2 | 商务主管 3 | 大区经理t_userid | name1 | 102 | 祖儿3 | 杰伦hibernate多对多关联映射(双向User<->Role)映射方法:<set name="roles" table="t_user_role"><key column="userid"/><many-to-many class="com.bjsxt.hibernate.Role" column="roleid"/></set>table属性值必须和单向关联中的table属性值一致<key>中column属性值要与单向关联中的<many-to-many>标签中的column属性值一致在<many-to-many>中的column属性值要与单向关联中<key>标签的column属性值一致六、继承关联映射1、每棵继承树映射成一张表每棵继承树映射成一张表t_animalidnamesexweightheighttype1猪猪true100P2鸟鸟false50B每棵继承树映射成一张表(1)、理解如何映射因为类继承树肯定是对应多个类,要把多个类的信息存放在一张表中,必须有某种机制来区分哪些记录是属于哪个类的。这种机制就是,在表中添加一个字段,用这个字段的值来进行区分。用hibernate实现这种策略的时候,有如下步骤:父类用普通的<class>标签定义在父类中定义一个discriminator,即指定这个区分的字段的名称和类型如:<discriminator column=”XXX” type=”string”/>子类使用<subclass>标签定义,在定义subclass的时候,需要注意如下几点:Subclass标签的name属性是子类的全路径名在Subclass标签中,用discriminator-value属性来标明本子类的discriminator字段(用来区分不同类的字段)的值.Subclass标签,既可以被class标签所包含(这种包含关系正是表明了类之间的继承关系),也可以与class标签平行。 当subclass标签的定义与class标签平行的时候,需要在subclass标签中,添加extends属性,里面的值是父类的全路径名称。子类的其它属性,像普通类一样,定义在subclass标签的内部。(2)、理解如何存储存储的时候hibernate会自动将鉴别字段值插入到数据库中,在加载数据的时候,hibernate能根据这个鉴别值正确的加载对象(3)多态查询:在hibernate加载数据的时候能鉴别出正真的类型(instanceOf)get支持多态查询load只有在lazy=false,才支持多态查询 hql支持多态查询 (4)extends.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 package="com.bjsxt.hibernate"><class name="Animal" table="t_animal" lazy="false"><id name="id"><generator class="native"/></id><discriminator column="type" type="string"/><property name="name"/><property name="sex"/><subclass name="Pig" discriminator-value="P"><property name="weight"/></subclass><subclass name="Bird" discriminator-value="B"><property name="height"/></subclass></class></hibernate-mapping>2、每个类映射成一张表每个子类映射成一张表t_animalidnamesex1猪猪true2鸟鸟falset_pigpidweight1100t_birdbidheight250每个子类映射成一张表(1)、理解如何映射这种策略是使用joined-subclass标签来定义子类的。父类、子类,每个类都对应一张数据库表。在父类对应的数据库表中,实际上会存储所有的记录,包括父类和子类的记录;在子类对应的数据库表中,这个表只定义了子类中所特有的属性映射的字段。子类与父类,通过相同的主键值来关联。实现这种策略的时候,有如下步骤:父类用普通的<class>标签定义即可父类不再需要定义discriminator字段子类用<joined-subclass>标签定义,在定义joined-subclass的时候,需要注意如下几点:Joined-subclass标签的name属性是子类的全路径名Joined-subclass标签需要包含一个key标签,这个标签指定了子类和父类之间是通过哪个字段来关联的。如:<key column=”PARENT_KEY_ID”/>,这里的column,实际上就是父类的主键对应的映射字段名称。Joined-subclass标签,既可以被class标签所包含(这种包含关系正是表明了类之间的继承关系),也可以与class标签平行。 当Joined-subclass标签的定义与class标签平行的时候,需要在Joined-subclass标签中,添加extends属性,里面的值是父类的全路径名称。子类的其它属性,像普通类一样,定义在joined-subclass标签的内部。(2)extends.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 package="com.bjsxt.hibernate"><class name="Animal" table="t_animal"><id name="id"><generator class="native"/></id><property name="name"/><property name="sex"/><joined-subclass name="Pig" table="t_pig"><key column="pid"/><property name="weight"/></joined-subclass><joined-subclass name="Bird" table="t_bird"><key column="bid"/><property name="height"/></joined-subclass></class></hibernate-mapping>3、每个具体类映射成一张表每个具体类映射成一张表t_pigidnamesexweight1猪猪true100t_birdidnamesexheight2鸟鸟false50每个具体类映射成一张表(1)如何映射这种策略是使用union-subclass标签来定义子类的。每个子类对应一张表,而且这个表的信息是完备的,即包含了所有从父类继承下来的属性映射的字段(这就是它跟joined-subclass的不同之处,joined-subclass定义的子类的表,只包含子类特有属性映射的字段)。实现这种策略的时候,有如下步骤:父类用普通<class>标签定义即可子类用<union-subclass>标签定义,在定义union-subclass的时候,需要注意如下几点:Union-subclass标签不再需要包含key标签(与joined-subclass不同)Union-subclass标签,既可以被class标签所包含(这种包含关系正是表明了类之间的继承关系),也可以与class标签平行。 当Union-subclass标签的定义与class标签平行的时候,需要在Union-subclass标签中,添加extends属性,里面的值是父类的全路径名称。子类的其它属性,像普通类一样,定义在Union-subclass标签的内部。这个时候,虽然在union-subclass里面定义的只有子类的属性,但是因为它继承了父类,所以,不需要定义其它的属性,在映射到数据库表的时候,依然包含了父类的所有属性的映射字段。注意:在保存对象的时候id是不能重复的(不能使用自增生成主键)(2)extends.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 package="com.bjsxt.hibernate"><class name="Animal" abstract="true"><id name="id"><generator class="assigned"/></id><property name="name"/><property name="sex"/><union-subclass name="Pig" table="t_pig"><property name="weight"/></union-subclass><union-subclass name="Bird" table="t_bird"><property name="height"/></union-subclass></class></hibernate-mapping>

    注意事项

    本文(hibernate各种关联关系.doc)为本站会员(罗晋)主动上传,三一文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    经营许可证编号:宁ICP备18001539号-1

    三一文库
    收起
    展开