mybatis关联关系映射
1、一对多关联关系
2、多对多关联关系
首先先用逆向生成工具生成t_hibernate_order、t_hibernate_order_item
t_hibernate_book、t_hibernate_book_category、t_hibernate_category
这五张表对应的model与mapper
配置mybatis-generator插件生成文件位置
修改generatorConfig.xml配置文件的生成目录(mapper和model)及对应生成关系
创建实体类:
package com.lingerqi.model.vo; import com.lingerqi.model.Horder;
import com.lingerqi.model.Horderitem; import java.util.ArrayList;
import java.util.List; /**
* @author xyls
* @create 2019-10-23 10:43
*/
public class OrderVo extends Horder { private List<Horderitem> horderitems = new ArrayList<>(); public List<Horderitem> getHorderitems() {
return horderitems;
} public void setHorderitems(List<Horderitem> horderitems) {
this.horderitems = horderitems;
}
@Override
public String toString() {
return "OrderVo{" +
"horderitems=" + horderitems +
'}';
}
}
package com.lingerqi.model.vo; import com.lingerqi.model.Horder;
import com.lingerqi.model.Horderitem; /**
* @author xyls
* @create 2019-10-23 10:46
*/
public class HorderitemVo extends Horderitem {
private Horder horder; public Horder getHorder() {
return horder;
} public void setHorder(Horder horder) {
this.horder = horder;
} @Override
public String toString() {
return "HorderitemVo{" +
"horder=" + horder +
'}';
}
}
HorderMapper.xml:
<resultMap id="OrderVoMap" type="com.lingerqi.model.vo.OrderVo" >
<result property="orderId" column="order_id"></result>
<result property="orderNo" column="order_no"></result>
<collection property="orderItems" ofType="com.lingerqi.model.Horderitem">
<result property="orderItemId" column="order_item_id"></result>
<result property="oid" column="oid"></result>
<result property="productId" column="product_id"></result>
<result property="quantity" column="quantity"></result>
</collection>
</resultMap>
<select id="selectByOrderId" resultMap="OrderVoMap" parameterType="java.lang.Integer">
select * from t_hibernate_order o,t_hibernate_order_item oi where o.ordre_id=oi.oid
and oi.order_id=#{orderId}
</select>
@Repository
public interface HorderMapper {
List<OrderVo> selectByOrderId(@Param("orderId") Integer orderId);
}
HorderitemMapper.xml
<resultMap id="OrderItemVoMap" type="com.lingerqi.model.vo.HorderitemVo">
<result property="orderItemId" column="order_item_id"></result>
<result property="productId" column="product_id"></result>
<result property="quantity" column="quantity"></result>
<result property="oid" column="oid"></result>
<!--<result property="orderItems"></result>-->
<association property="order" javaType=" com.lingerqi.model.Horder">
<result property="orderId" column="order_id"></result>
<result property="orderNo" column="order_no"></result>
</association>
</resultMap>
<select id="selectByOrderItemId" resultMap="OrderItemVoMap" parameterType="java.lang.Integer">
select * from t_hibernate_order o,t_hibernate_order_item oi where o.ordre_id=oi.oid
and oi.order_item_id =#{orderItemId}
</select>
@Repository
public interface HorderitemMapper {
List<HorderitemVo> selectByOrderItemId(@Param("orderItemId") Integer orderItemId);
}
package com.lingerqi.Service; import com.lingerqi.model.vo.HorderitemVo;
import com.lingerqi.model.vo.OrderVo; import java.util.List; /**
* @auther xyls
* @create 2019-10-23-18:19
*/
public interface OneToManyService {
List<OrderVo> selectByOrderId(Integer orderId); List<HorderitemVo> selectByOrderItemId(Integer orderItemId); }
public class OneToManyServiceImplTest extends SpringBaseTest {
@Autowired
private OneToManyService oneToManyService;
@Test
public void selectByOrderId() {
List<OrderVo> orderVos = oneToManyService.selectByOrderId(8);
OrderVo orderVo=orderVos.get(0);
System.out.println(orderVos);
for (OrderItem orderItem : orderVo.getOrderItems()) {
System.out.println(orderItem);
}
}
@Test
public void selectByOrderItemId() {
List<OrderItemVo> orderItemVos = oneToManyService.selectByOrderItemId(36);
OrderItemVo orderItemVo=orderItemVos.get(0);
System.out.println(orderItemVo);
System.out.println(orderItemVo.getOrder());
}
}


package com.lingerqi.mapper;
import com.lingerqi.model.HbookCategory;
public interface HbookCategoryMapper {
int deleteByPrimaryKey(Integer bcid);
int insert(HbookCategory record);
int insertSelective(HbookCategory record);
HbookCategory selectByPrimaryKey(Integer bcid);
int updateByPrimaryKeySelective(HbookCategory record);
int updateByPrimaryKey(HbookCategory record);
}
package com.lingerqi.service.impl; import com.lingerqi.service.ManyToManyService;
import com.lingerqi.mapper.CategoryMapper;
import com.lingerqi.mapper.HbookMapper;
import com.lingerqi.model.vo.CategoryVo;
import com.lingerqi.model.vo.HbookVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; /**
* @auther xyls
* @create 2019-10-24-11:11
*/
@Service
public class ManyToManyServiceImpl implements ManyToManyService {
@Autowired
private HbookMapper hbookMapper;
@Autowired
private CategoryMapper categoryMapper;
@Override
public HbookVo selectByBid(Integer bid) {
return hbookMapper.selectByBid(bid);
} @Override
public CategoryVo selectByCid(Integer cid) {
return categoryMapper.selectByCid(cid);
}
}
package com.lingerqi.service.impl; import com.lingerqi.SpringBaseTest;
import com.lingerqi.model.Category;
import com.lingerqi.model.Hbook;
import com.lingerqi.model.vo.CategoryVo;
import com.lingerqi.model.vo.HbookVo;
import com.lingerqi.service.ManyToManyService;
import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired; /**
* @auther xyls
* @create 2019-10-24-11:13
*/
public class ManyToManyServiceImplTest extends SpringBaseTest { @Autowired
private ManyToManyService manyToManyService;
@Test
public void selectByBid() {
HbookVo hbookVo=manyToManyService.selectByBid(8);
System.out.println(hbookVo);
for (Category category : hbookVo.getCategories()) {
System.out.println(category);
}
} @Test
public void selectByCid() {
CategoryVo categoryVo = this.manyToManyService.selectByCid(8);
System.out.println(categoryVo);
for (Hbook hbook : categoryVo.getHbooks()) {
System.out.println(hbook);
} }
}

mybatis关联关系映射的更多相关文章
- mybatis之关联关系映射
Mybatis关联关系映射 1.一对多 首先先用逆向生成工具生成t_hibernate_order.t_hibernate_order_item 这两张表对应的model与mapper OrderVo ...
- Mybatis输入输出映射_动态sql_关联关系(一对一、一对多、多对多)
Mybatis输入输出映射_动态sql_关联关系(一对一.一对多.多对多)输入输出映射parameterType完成输入映射parameterType可以传入的参数有,基本数据类型(根据id查询用户的 ...
- mybatis多对多关联关系映射
mybatis多对多关联关系映射 多对多关系在java类实体中表示为,一个类中包含了集合为另一个类的属性.而这连个实体都需要包含对方的集合类的属性. 例如:订单和商品,一个订单包含多个商品,一个商品又 ...
- mybatis一对多关联关系映射
mybatis一对多关联关系映射 一对多关联关系只需要在多的一方引入少的一方的主键作为外键即可.在实体类中就是反过来,在少的一方添加多的一方,声明一个List 属性名 作为少的一方的属性. 用户和订单 ...
- mybatis一对一关联关系映射
mybatis一对一关联关系映射 在关联关系中,有一对一,一对多,多对多三种关联关系. 一对一关系:在操作上,任意一方引入对方的主键作为外键. 一对多关系:在"多"的一方添加&qu ...
- Hibernate(6)—— 一对多 和 多对多关联关系映射(xml和注解)总结
俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及的知识点总结如下: One to Many 映射关系 多对一单向外键关联(XML/Annotation) 一对多单向外键关联(XM ...
- Hibernate—— 一对多 和 多对多关联关系映射(xml和注解)总结(转载)
One to Many 映射关系 多对一单向外键关联(XML/Annotation) 一对多单向外键关联(XML/Annotation) 懒加载和积极加载 一对多双向外键关联(XML/Annotati ...
- MyBatis 关系映射XML配置
关系映射 在我看来这些实体类就没啥太大关联关系,不就是一个sql语句解决的问题,直接多表查询就完事,程序将它设置关联就好 xml里面配置也是配置了sql语句,下面给出几个关系的小毛驴(xml) 一对多 ...
- Mybatis sql映射文件浅析 Mybatis简介(三)
简介 除了配置相关之外,另一个核心就是SQL映射,MyBatis 的真正强大也在于它的映射语句. Mybatis创建了一套规则以XML为载体映射SQL 之前提到过,各项配置信息将Mybatis应用的整 ...
随机推荐
- JavaScript定时器方法
一.setTimeout() 延迟性操作 window.setTimeout(function(){ console.log('派大星');//延迟了4秒 },4000); console.log(' ...
- git worktree 使用笔记
一 worktree 的基本概念和操作 再也不用克隆多个仓库啦!git worktree 一个 git 仓库可以连接多个工作目录 - walterlv的专栏 - CSDN博客 再也不用克隆多个仓库啦! ...
- JS基础语法---总结
JS是一门什么样的语言? 是一门解释性的语言 是一门脚本语言 是一门弱类型语言,声明变量都用var 是一门基于对象的语言 是一门动态类型的语言: 1. 代码(变量)只有执行到这个 ...
- apk系统签名小技巧
前言 对于经常和android系统打交道的攻城狮来说,给app打系统签名一定是日常操作啦.由于最近使用的比较多,特此总结一下,减少复制粘贴的操作,通过命令行来搞定. 简化前的操作 1.Android ...
- 团队项目之团队展示&选题
团队博文:https://www.cnblogs.com/blackpanda/p/11734448.html 一. 团队展示 1. 队名: Black Panda 2. 队员: 郑伟金 3117 ...
- iperf 一个测试网络吞吐的工具
在分布式文件系统开发和测试过程中,我们经常需要测试真实的网络带宽,来进行估测分布式系统的传输性能,所以我们要对现有的网络进行测试:Iperf 是一个网络性能测试工具.IPerf可以测试最大的TCP和U ...
- Linux—软连接与硬连接
软链接的创建,删除,修改 创建软链接:ln -s[目标文件或目录][软链接地址] 解释:软链接地址相当于快捷方式,目标文件或目录才是真正的内容.[软链接地址]指“快捷键”文件名称,该文件是被指令创建的 ...
- 【5】Android Service 与 AIDL
前言:本系列仅介绍基本大体的使用步骤,而不对每个步骤进行细致的讲解.读者可作为已经对相关内容有所了解后的快速查阅. 一.单应用内Service的使用 Service组件与Activity以IBinde ...
- eNSP仿真软件之VLAN基础配置及Access接口
★Access接口是交换机上用来连接用户主机的接口. 实验内容: 实验步骤: (1) 打开仿真软件eNSP,新建拓扑.根据实验内容建立如下实验拓扑图. (2) 按照如下的编址表对每 ...
- PHP的stdClass
概述 以下是百度百科对php中的 stdClass的描述: stdClass在PHP5才开始被流行.而stdClass也是zend的一个保留类.stdClass类是PHP的一个内部保留类,初始时没有成 ...