网站转化率是什么意思,成都捕鱼网站建设,做网站教程流程,网站购买广告位目录 关联关系映射
一对一关联#xff1a;
一对多关联#xff1a;
多对多关联#xff1a;
导入数据库表 一对多
一对一 多对多 关联关系映射
关联关系映射在Mybatis中主要通过三种方式实现#xff1a;一对一关联和一对多关联及多对多关联。
一对一关联#xff1a;…目录 关联关系映射
一对一关联
一对多关联
多对多关联
导入数据库表 一对多
一对一 多对多 关联关系映射
关联关系映射在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 ListOrderItem orderItems new ArrayListOrderItem();public ListOrderItem getOrderItems() {return orderItems;}public void setOrderItems(ListOrderItem 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 {Autowiredprivate OrderMapper orderMapper;Overridepublic 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 {Autowiredprivate OrderMapper orderMapper;Overridepublic 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 {Autowiredprivate HBookMapper hBookMapper;Overridepublic HbookVo selectByBookId(Integer bid) {return hBookMapper.selectByBookId(bid);}
}