温馨提示×

温馨提示×

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

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

Hibernate一对多,多对一,多对多,一对一关系怎么实现

发布时间:2021-12-06 09:30:50 来源:亿速云 阅读:134 作者:iii 栏目:编程语言

这篇文章主要讲解了“Hibernate一对多,多对一,多对多,一对一关系怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Hibernate一对多,多对一,多对多,一对一关系怎么实现”吧!

本文中用到的三个实例化类分别为Customer(保存客户基本信息),CustomerDetails(保存客户详细信息),CustomerBack(中间表,保存两表之间的关联)
对应的表功能同上.说明中的主表指Customer,子表指CustomerDetails,中间表指CustomerBack

一对多

﹤set name="CustomerDetails" table="customer_details" 
inverse="false" cascade="all" sort="unsorted" ﹥  
 ﹤key column="cust_Id"/﹥ 
﹤one to many class="com.hibernate.otm.CustomerDetails"/﹥ ﹤/set﹥

这段代码是需要放在一对多中的主表配置中的

◆name:集合属性的名称(也可以理解为一对多中那个子属性名)

◆table(可选,默认为属性的名称):集合表的名称(可理解为一对多中子表的名称)

◆inverse(可选,默认为false):标记这个集合作为双向关联关系中的方向的一端

◆cascade(可选:默认为none):让操作级联到子实体

◆sort(可选):指定集合的排序顺序

其它如schema,lazy,order–by,where,outer–join,batch–size,access请参照有关书籍.

key 中的column=”cust_Id”,cust_Id并不是主表的字段,而是子表中保存主表的字段.
如主表主键为cust_Id,子表中为了保存主表的主键,也建一个cust_Id,key里的cust_Id就是指子表中的cust_Id.
one–to–many 中的class为一对多的子表实例类.

多对一

﹤many to one
    name="Customer"
    class="Customer"
    cascade="all"
    outer join="false"
    update="false"
    insert="false"
    column="cust_Id"
    not null="true"/﹥

多对一中,没有像一对多的,而是直接用了many–to–one.这段代码是需要放在多对一中的子表配置中的(即CustomerDetails的配置中)

◆outer–join:为外链接

◆update,insert:指定对应的字段是否在用于UPDATE和/或INSERT的SQL语句中包含.

◆column:关联的字段名.(多对主类对应的字段名)

◆not–null:是否为null.

多对多

﹤set name="CustomerBack" table="customer_back" cascade="all"﹥ ﹤key column="cust_Id"/﹥ ﹤many to many class="CustomerDetails" column="custD_id"/﹥ ﹤/set﹥

多对多的配置与一对多有点类似.这段代码放的位置也是与一对多的代码放的位置一样.
多对多关系中,多采用中间表来关联两个有多多关系的表的.如Customer与CustomerDetails存在多对多的关系,那么往往是用另外一个表如CustomerBack表来保存它们的关系的,也就是中间表.

◆name:属性的名称(可理解为中间表的名称)

◆table:表的名称(可理解为中间表的表名称)

◆key 里的cust_Id,是指中间表的cust_Id,为了保存Customer与CustomerDetails的关系,中间表中分别建了cust_Id(Customer的主键)与custD_Id(CustomerDetails的主键)

◆many–to–many中的Class是指多对多中的另一个实例化类,column是指CustomerDetails与中间表关联的字段名.这里是指中间表的

◆custD_Id,不能理解为CustomerDetails的主键.

一对一

﹤one to one name="CustomerDetails" class="CustomerDetails" cascade="all" /﹥
一对一的关系更简单.
在Customer表的配置中放上这段代码就行了.

◆name:属性名称

◆class:关联的实例化类名

感谢各位的阅读,以上就是“Hibernate一对多,多对一,多对多,一对一关系怎么实现”的内容了,经过本文的学习后,相信大家对Hibernate一对多,多对一,多对多,一对一关系怎么实现这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

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

AI