MyBatis一对多嵌套查询的完整实例

前言

嵌套查询的实现原理为两次查询,比如产品表为主表,图片表为从表通过product_id字段与产品表id字段关联实现一对多,嵌套查询 首先查询 主表的数据 然后将主表id字段赋值给从表实体类中product_id 字段(productId)然后通过dao接口路径映射找到对应的MyBatis XMl文件SQL语句ID如:com.liao.dao.DImgMapper.selectDImgByProductId 进行子查询也就是第二次查询。然后返回数据

数据库建表语句和测试数据如下:

数据库版本为 MySQL 8.0

产品表

DROP TABLE IF EXISTS `d_product`;
CREATE TABLE `d_product` (
 `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '产品ID',
 `product_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL COMMENT '产品名称',
 `product_introduction` text CHARACTER SET utf8 COLLATE utf8_bin NULL COMMENT '产品介绍',
 `product_category` int(11) NULL DEFAULT NULL COMMENT '产品ID',
 `product_status` int(1) NULL DEFAULT NULL COMMENT '产品状态',
 `create_time` datetime(0) NULL DEFAULT NULL COMMENT '创建时间',
 PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 18 CHARACTER SET = utf8 COLLATE = utf8_bin COMMENT = '产品表' ROW_FORMAT = Dynamic;

INSERT INTO `d_product` VALUES (1, '测试产品名称修改', '测试产品介绍修改', NULL, 1, '2020-02-02 12:40:06');
INSERT INTO `d_product` VALUES (2, '产品名称', '产品介绍', NULL, 1, '2020-03-02 18:15:07');
INSERT INTO `d_product` VALUES (3, 'bbb', 'bbb', NULL, 1, '2020-03-01 22:18:40');

图片表

DROP TABLE IF EXISTS `d_img`;
CREATE TABLE `d_img` (
 `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'id',
 `product_id` int(11) NULL DEFAULT NULL COMMENT '产品图片ID',
 `img` varchar(500) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL COMMENT '图片',
 `create_time` datetime(0) NULL DEFAULT NULL COMMENT '创建时间',
 PRIMARY KEY (`id`) USING BTREE,
 INDEX `product_id`(`product_id`) USING BTREE,
 CONSTRAINT `d_img_ibfk_1` FOREIGN KEY (`product_id`) REFERENCES `d_product` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE = InnoDB AUTO_INCREMENT = 86 CHARACTER SET = utf8 COLLATE = utf8_bin COMMENT = '产品图片' ROW_FORMAT = Dynamic;

INSERT INTO `d_img` VALUES (40, 1, '1491803633034_683819.jpg', '2020-03-03 17:21:20');
INSERT INTO `d_img` VALUES (40, 1, '1491803633034_683819.jpg', '2020-03-03 17:21:20');
INSERT INTO `d_img` VALUES (41, 1, '1568950881751_702421.jpg', '2020-03-03 17:21:20');

Java实体类:

// 将这个注解写在类上之后,就会忽略类中不存在的字段,否则可能会报错
@JsonIgnoreProperties(value = {"handler"})
/**
 *
 * TODO: 产品类
 * @author LiAo
 * @date 2020/5/20 17:04
 */
public class DProduct {
 private Integer id;

 private String productName;

 private Integer productCategory;

 private Integer productStatus;

 private Date createTime;

 private String productIntroduction;

 private List<DImg> dImgs;  // 用于存放图片集合

 // .. get set toString
}

/**
 *
 * TODO: 产品图片类
 * @author LiAo
 * @date 2020/5/20 17:05
 */
@JsonIgnoreProperties(value = {"handler"})
public class DImg {
 private Integer id;

 private Integer productId;

 private String img;

 private Date createTime;

 // .. get set toString
}

实体类创建好后要编写Dao接口 和Mapper XML了

持久层接口DAO:

/**
 *
 * TODO: 产品 Dao接口
 * @author LiAo
 * @date 2020/5/20 17:08
 */
public interface DProductMapper {
 /**
  * 产品图片一对多嵌套
  * @param record 查询条件
  * @return 返回参数
  */
 List<DProduct> productSelect(DProduct record);
}

产品MyBatis xml:

<!--映射的Dao接口类 可以通过这个路径找到先关的SQL语句和resultMap 映射-->
<mapper namespace="com.liao.dao.DProductMapper">
 <resultMap id="BaseResultMap" type="com.liao.entity.DProduct">
  <id column="id" property="id" jdbcType="INTEGER"/>
  <result column="product_name" property="productName" jdbcType="VARCHAR"/>
  <result column="product_category" property="productCategory" jdbcType="INTEGER"/>
  <result column="product_status" property="productStatus" jdbcType="INTEGER"/>
  <result column="create_time" property="createTime" jdbcType="TIMESTAMP"/>
  <result column="product_introduction" property="productIntroduction" jdbcType="LONGVARCHAR"/>
 </resultMap>
 <!--产品图片一对多查询映射-->
 <!--id:配置映射的名称-->
 <!--type:返回值类型 -->
 <!--extends:继承id为BaseResultMap的映射 -->
 <!--select:子查询所在的XML绑定的DAO接口路径.SQL语句id -->
 <!--column="{productId = id} productId:从表关联主表的实体类属性,作为子查询的条件 id:主表中被关联的数据库字段-->
 <resultMap id="dProductResultMap" type="com.liao.entity.DProduct" extends="BaseResultMap">
  <collection property="dImgs" fetchType="lazy"
     select="com.liao.dao.DImgMapper.selectDImgByProductId" column="{productId = id}"/>
 </resultMap>

 <!--查询语句-->
 <select id="productSelect" parameterType="com.liao.entity.DProduct" resultMap="dProductListMapSelect">
 select
 d.id,
 d.product_name,
 d.product_category,
 d.product_status,
 d.create_time,
 d.product_introduction
 from d_product d
 where 1 = 1
 <!-- 使用if标签拼接条件语句 实现动态SQL-->
 <if test="id != null and id != ''">
  and d.id = #{id}
 </if>
 <if test="productName != null and productName != ''">
  and d.product_name like concat(#{productName},'%')
 </if>
 <if test="productStatus != null and productStatus != ''">
  and d.product_status = #{productStatus}
 </if>
 <if test="createTime != null and createTime != ''">
  and d.create_time like concat(#{createTime},'%')
 </if>
 <if test="productIntroduction != null and productIntroduction != ''">
  and d.product_introduction like concat(#{productIntroduction},'%')
 </if>
</select>
</mapper>

图片MyBatis xml:

<mapper namespace="com.liao.dao.DImgMapper">
 <resultMap id="BaseResultMap" type="com.liao.entity.DImg">
  <id column="did" property="id" jdbcType="INTEGER"/>
  <result column="product_id" property="productId" jdbcType="INTEGER"/>
  <result column="img" property="img" jdbcType="VARCHAR"/>
  <result column="create_time" property="createTime" jdbcType="TIMESTAMP"/>
 </resultMap>
 <!--一对多嵌套查询 子查询语句-->
 <select id="selectDImgByProductId" resultMap="BaseResultMap">
  select i.id as did,
    i.product_id,
    i.img,
    i.create_time
  from d_img i
  where i.product_id = #{productId}
 </select>
</mapper>

测试查询结果

查询结果为一个产品对象里有若干个产品图片对象。

 			{
 				"id": 18,
    "productName": "产品添加图片上传测试",
    "productCategory": null,
    "productStatus": 1,
    "createTime": "2020-04-14T13:40:40.000+0000",
    "productIntroduction": "产品添加图片上传测试",
    "dImgs": [
     {
      "id": 92,
      "productId": 18,
      "img": "01.jpg",
      "createTime": "2020-04-26T02:33:04.000+0000"
     },
     {
      "id": 93,
      "productId": 18,
      "img": "1554103835292_610234.jpg",
      "createTime": "2020-04-26T02:33:04.000+0000"
     },
     {
      "id": 94,
      "productId": 18,
      "img": "1555484699771_582172.jpg",
      "createTime": "2020-04-26T02:33:04.000+0000"
     },
     {
      "id": 95,
      "productId": 18,
      "img": "1554103835292_610234.jpg",
      "createTime": "2020-04-26T02:33:04.000+0000"
     }
    ]
   },

总结

到此这篇关于MyBatis一对多嵌套查询的文章就介绍到这了,更多相关MyBatis一对多嵌套查询内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • mybatis一对多查询功能

    首先,我们还是先给出一个需求:根据订单id查询订单明细--我们知道,一个订单里面可以有多个订单的明细(需求不明确的同学,请留言或者去淘宝网上的订单处点一下就知道了).这个时候,一个订单,对应多个订单的id.这种需求出现的时候,我们应该如何查询呢? 此时我们的数据模型如下图(左)由于查询用户也是我们的需求,所以就在原有的基础上进行扩展,数据模型如下(右): 很显然,如果用resultType的方式去实现的话,是不合理的了.因为我们需要创建一个既有订单又有订单明细的pojo然后呢,我们的mybati

  • Mybatis 一对多和多对一关联查询问题

    首先  数据库量表之间字段关系(没有主外键) studentmajor表的id字段对应student表里major字段 两个实体类 package com.model; import java.util.Date; public class Student { private Integer sno; private String sname; private String ssex; private Integer sclass; private StudentMajor studentmaj

  • MyBatis的嵌套查询解析

    Mybatis表现关联关系比hibernate简单,没有分那么细致one-to-many.many-to-one.one-to-one.而是只有两种association(一).collection(多),表现很简洁.下面通过一个实例,来展示一下Mybatis对于常见的一对多和多对一关系复杂映射是怎样处理的. 以最简单的用户表订单表这个最简单的一对多做示例: 对应的JavaBean: User: public class User { private int id; private String

  • mybatis 一对一、一对多和多对多查询实例代码

    关键字:association 一对一映射(一个班级只有一个班主任) <select id="getClass" parameterType="int" resultMap="ClassesResultMap"> select * from class c,teacher t where c.teacher_id=t.t_id and c.c_id=#{id} </select> <resultMap type=&q

  • Mybatis中连接查询和嵌套查询实例代码

    首先在mysql中确立表: #表一:地址国家表 CREATE TABLE address(aid INT AUTO_INCREMENT PRIMARY KEY,aname VARCHAR(20)); INSERT INTO address VALUES(NULL,"魏国"); INSERT INTO address VALUES(NULL,"蜀国"); INSERT INTO address VALUES(NULL,"吴国"); #表二:出场人物

  • MyBatis一对多嵌套查询的完整实例

    前言 嵌套查询的实现原理为两次查询,比如产品表为主表,图片表为从表通过product_id字段与产品表id字段关联实现一对多,嵌套查询 首先查询 主表的数据 然后将主表id字段赋值给从表实体类中product_id 字段(productId)然后通过dao接口路径映射找到对应的MyBatis XMl文件SQL语句ID如:com.liao.dao.DImgMapper.selectDImgByProductId 进行子查询也就是第二次查询.然后返回数据 数据库建表语句和测试数据如下: 数据库版本为

  • mybatis一对多两种mapper写法实例

    mybatis一对多两种mapper写法 第一种 <resultMap type="com.example.demo.model.TuserModel" id="extendMapper"> <id column="id" property="id" /> <result column="user_name" property="userName" />

  • mybatis使用collection嵌套查询的实现

    在开发中,可能会遇到一对多的关系,这个时候,一条sql语句就难以胜任这个任务了.只能先执行一条sql,然后根据返回的结果,再做一次sql关联查询,这个时候,使用mybatis的collection就可以实现. 如果第一次查询返回的是一个list集合,那么,后续的查询就是一个for循环.所以不使用collection的做法,在java语言中,就要分两次查询.一般而言,我们的列表查询都是分页查询,所以集合数据不会太大,第二次for循环查询效率还好. 下面介绍mybatis使用collection嵌套

  • 解决mybatis一对多关联查询多条数据只显示一条的问题

    一对多,如果多个表字段名相同,要记住使用别名,否则多条数据只显示一条 <resultMap type="com.example.demo.model.TuserModel" id="extendMapper"> <id column="id" property="id" /> <result column="user_name" property="userName&

  • oracle日期分组查询的完整实例

    前言 在做数据报表时,需要对某一时间段分组,以1小时为时间间隔统计各项数据,如9点-10点,10点-11点-,但是现在有种情况,时间有可能不是整点开始,会有半点的情况,9点30,需要按照9点30-10点30,10点30-11点30分组统计 实现 以时间范围起始时间作为参照时间,计算与其差值(分)/所需时间间隔(1小时) 得出值作为分组依据. 例子 select xx, floor( floor( (refDate-to_date('2021-02-05 08:30','yyyy-MM-dd hh

  • springboot整合mybatis实现简单的一对多级联查询功能

    本文的目的是用springboot整合mybatis实现一个简单的一对多查询.(查询一个用户有多少件衣服) 第一步:数据库中,可以直接在navicat中建立两张我们需要用到的表 users DROP TABLE IF EXISTS `users`; CREATE TABLE `users` ( `id` int(0) NOT NULL AUTO_INCREMENT, `name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_

  • MyBatis中一对多的xml配置方式(嵌套查询/嵌套结果)

    目录 MyBatis一对多的xml配置 嵌套查询 嵌套结果 一对多关联查询xml配置写法 情景概述 创建表 对应javaPojo 查询客户表client获取客户名下的附件信息 查询客户附件表client_file获取附件所属的客户信息 小结一下 MyBatis一对多的xml配置 用的是window上面的画图板,没法以文字的方式展示出来,见谅 嵌套查询 嵌套结果 一对多关联查询xml配置写法 情景概述 1.有一张客户表 Client ,存储客户信息, 姓名 name ,年龄 age等. 2.有一张

  • mybatis 集合嵌套查询和集合嵌套结果的区别说明

    目录 集合嵌套查询和集合嵌套结果的区别 1.创建2张表,建立主外键关系 2.建立实体类 3.修改配置文件 4.建立映射文件 5.创建测试类 MyBatis 嵌套查询解析 对应的JavaBean 对应的数据库 嵌套语句查询 嵌套语句查询的原理 嵌套查询的多对一 嵌套查询的N+1问题 嵌套结果查询 嵌套结果查询的执行步骤 集合嵌套查询和集合嵌套结果的区别 嵌套查询是多条sql语句分开写并配置,嵌套结果是一条sql语句关联查询并配置,实质效果是一样的.嵌套语句的查询会导致数据库访问次数不定,进而有可能

随机推荐