目录
关联关系映射
一对一关联:
一对多关联:
多对多关联:
导入数据库表
一对多
一对一
多对多
关联关系映射
关联关系映射在Mybatis中主要通过三种方式实现:一对一关联和一对多关联及多对多关联。
一对一关联:
在一对一关联中,两个表之间存在一对一的关系,例如学生表和身份证表,一个学生只有一个身份证,而一个身份证也只属于一个学生。在Mybatis中,可以通过在实体类中定义关联属性,然后在映射文件中使用<association>标签来定义关联关系。通过配置映射关系,可以查询到学生表和身份证表的数据,并将其映射到对应的实体类中。
一对多关联:
在一对多关联中,两个表之间存在一对多的关系,例如部门表和员工表,一个部门可以有多个员工,而一个员工只属于一个部门。在Mybatis中,可以通过在实体类中定义关联属性,然后在映射文件中使用<collection>标签来定义关联关系。通过配置映射关系,可以查询到部门表和员工表的数据,并将其映射到对应的实体类中。
多对多关联:
是指两个表之间存在多对多的关联关系,即一个表的一条记录可以对应另一个表的多条记录,反之亦然。在数据库中,多对多关系通常需要通过中间表来实现。
在Mybatis中,可以通过定义中间表来映射多对多关系。假设有两个表,学生表和课程表,一个学生可以选择多门课程,而一门课程也可以被多个学生选择。为了映射这种多对多关系,需要创建一个中间表,例如选课表,用来记录学生和课程的关联关系。
导入数据库表
在generatorConfig.xml文件中,配置多张表
一对多
使用嵌套查询(Nested Queries):在主对象的映射配置中使用<collection>
标签来配置关联的多个子对象。可以通过select
语句查询子对象,并通过resultMap
将结果映射到主对象中。
创建一个 OrderVo
package com.xiaoxu.Vo;
import com.xiaoxu.model.Order;
import com.xiaoxu.model.OrderItem;
import java.util.ArrayList;
import java.util.List;
/**
* @author小徐
* @site www.veryedu.cn
* @company xu集团
* @create 2023-08-26 14:21
*/
public class OrderVo extends Order {
private List<OrderItem> orderItems = new ArrayList<OrderItem>();
public List<OrderItem> getOrderItems() {
return orderItems;
}
public void setOrderItems(List<OrderItem> orderItems) {
this.orderItems = orderItems;
}
}
建立一个resultMap映射
接着写biz层
package com.xiaoxu.impl;
import com.xiaoxu.Vo.OrderVo;
import com.xiaoxu.biz.OrderBiz;
import com.xiaoxu.mapper.OrderMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
* @author小徐
* @site www.veryedu.cn
* @company xu集团
* @create 2023-08-26 14:34
*/
@Service
public class OrderBizImpl implements OrderBiz {
@Autowired
private OrderMapper orderMapper;
@Override
public OrderVo selectByOid(Integer oid) {
return orderMapper.selectByOid(oid);
}
}
一对一
使用嵌套查询(Nested Queries):在主对象的映射配置中使用<association>
标签来配置关联的子对象。可以通过select
语句查询子对象,并通过resultMap
将结果映射到主对象中。
和之前一样,首先配置一个查询方法
biz层
package com.xiaoxu.impl;
import com.xiaoxu.Vo.OrderVo;
import com.xiaoxu.biz.OrderBiz;
import com.xiaoxu.mapper.OrderMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
* @author小徐
* @site www.veryedu.cn
* @company xu集团
* @create 2023-08-26 14:34
*/
@Service
public class OrderBizImpl implements OrderBiz {
@Autowired
private OrderMapper orderMapper;
@Override
public OrderVo selectByOid(Integer oid) {
return orderMapper.selectByOid(oid);
}
}
多对多
使用嵌套查询(Nested Queries):在中间表的映射配置中使用<collection>
标签来配置关联的多个子对象。可以通过select
语句查询子对象,并通过resultMap
将结果映射到中间表对象中。
还是一样先配置一个查询方法
biz层
package com.xiaoxu.impl;
import com.xiaoxu.Vo.HbookVo;
import com.xiaoxu.biz.HBookBiz;
import com.xiaoxu.mapper.HBookMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
* @author小徐
* @site www.veryedu.cn
* @company xu集团
* @create 2023-08-26 16:39
*/
@Service
public class HBookBizImpl implements HBookBiz {
@Autowired
private HBookMapper hBookMapper;
@Override
public HbookVo selectByBookId(Integer bid) {
return hBookMapper.selectByBookId(bid);
}
}