mybatis同一张表多次连接查询相同列赋值问题小结

最近遇到的一些问题总结:

1. MySQL数据库同一张表做四次左连接查询数据冗余。

a. mysql数据库连接查询

b. mysql表数据去重

2. mybatis查询相同列赋值重复问题。

a. 使用mybatis强大的resultMap

b. mysql数据查询别名

数据库表为

Create Table

CREATE TABLE `STUDENT_SCORE` (
 `score_id` int(11) unsigned NOT NULL AUTO_INCREMENT,//主键
 `test_id` int(11) NOT NULL,//标识考试信息
 `course` varchar(45) DEFAULT NULL,//课程名
 `score` float DEFAULT NULL,//分数
 PRIMARY KEY (`score_id`)
)

现在想要查询近四次考试改名同学的考试情况对比数据,查询语句如下:

SELECT score0.test_id, core0.course, score0.score, score1.score, score2.score, score3.score
FROM (SELECT * FROM STUDENT_SCORE WHERE test_id='11') score0
LEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id='12') score1
ON score0.course = score1.course
LEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id='13') score2
ON score0.course = score2.course
LEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id='14') score3
ON score0.course = score3.course

使用相同的sql语句写入mybatis的xml中:

<select id="findVCCFrameworkCompareData" parameterType="java.util.HashMap" resultMap="frameworkCompareMapper">
   SELECT
   score0.test_id,
   core0.course,
   score0.score,
   score1.score,
   score2.score,
   score3.score
   FROM (SELECT * FROM STUDENT_SCORE WHERE test_id=#{id0}) score0
   LEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id=#{id1}) score1
   ON score0.course = score1.course
   LEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id=#{id2}) score2
   ON score0.course = score2.course
   LEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id=#{id3}) score3
   ON score0.course = score3.course
</select>

以上查询执行结果全部未test_id=id0时的数据,将score1.test_idscore2.test_id添加至查询结果发现四个id值全部都为id0。

推测由于使用同一个表进行连接查询,列名相同,赋值时赋了相同的值。

在网上搜索有看到通过在resultMap中配置<collection><asociation>解决此问题。

尝试配置resultMap未果。

通过给表查询添加别名将以上查询语句修改如下,解决参数赋值冲突的问题。

SELECT
score0.test_id,
core0.course,
score0.score,
score1.score,
score2.score,
score3.score
FROM (SELECT * FROM STUDENT_SCORE score0 WHERE score0.test_id=#{score0}) score0
LEFT JOIN (SELECT * FROM STUDENT_SCORE score1 WHERE score1.test_id=#{score1}) score1
ON score0.course = score1.course
LEFT JOIN (SELECT * FROM STUDENT_SCORE score2 WHERE score2.test_id=#{score2}) score2
ON score0.course = score2.course
LEFT JOIN (SELECT * FROM STUDENT_SCORE score3 WHERE score3.test_id=#{score3}) score3
ON score0.course = score3.course

总结:

1、处理问题时力求正确简洁,切记多个问题混杂在一起影响问题定位与解决思路。

2、在进行多个表查询时,尽量使用别名对表进行重命名加以区分。

3、使用group by去重,后面跟哪一列对哪一列去重。

以上所述是小编给大家介绍的mybatis同一张表多次连接查询相同列赋值问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • mybatis同一张表多次连接查询相同列赋值问题小结

    最近遇到的一些问题总结: 1. MySQL数据库同一张表做四次左连接查询数据冗余. a. mysql数据库连接查询 b. mysql表数据去重 2. mybatis查询相同列赋值重复问题. a. 使用mybatis强大的resultMap b. mysql数据查询别名 数据库表为 Create Table CREATE TABLE `STUDENT_SCORE` ( `score_id` int(11) unsigned NOT NULL AUTO_INCREMENT,//主键 `test_id

  • 解析Mybatis对sql表的一对多查询问题

    Mybatisd对sql表的一对多查询 select * from projectrecord pr left join projects po on po.pid=pr.pid left join emp e on e.empno = pr.empno where pr.pid=1 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.or

  • MySQL系列多表连接查询92及99语法示例详解教程

    目录 1.笛卡尔积现象 2.连接查询知识点概括 1)什么是连接查询? 2)连接查询的分类 3.内连接讲解 1)等值连接:最大特点是,连接条件为等量关系. 2)sql92语法和sql99语法的区别. 3)非等值连接:最大特点是,连接条件为非等量关系. 4)自连接:最大特点是,一张表看作两张表. 4.外连接讲解 1)什么是外连接,和内连接有什么区别? 2)外连接的分类 前面两天带着大家换了一个口味,带着大家学习了pyecharts的原理和部分图形制作.今天我们继续回归带你学MySQL系列,带着大家继

  • 最简单的MyBatis Plus的多表联接、分页查询实现方法

    一.前言 最近在加强 ITAEM 团队的一个 app 项目--学生教师学习交流平台 人员组成:安卓 + 前端 + 后台 后台 DAO 层借鉴了华工其他软件开发团队,使用了新颖强大的 MyBatisPlus 框架,里边有一个类似百度贴吧的发帖子的功能: 而如果设计表,应为 帖子表 t_post - id - title 标题 - content 内容 - xx - user_id 用户外键 用户表 t_user + id + name 帖子发起者名字 + xx 示例图中红色框中的内容为 t_use

  • 经典mysql连接查询例题

    MySQL连接查询相信大家都有所了解,连接查询是在数据库查询操作的时候经常用到的,下面就为您介绍MySQL连接查询 mysql连接查询:支持多表连接 对同一张表可以重复连接多次(别名在多次连接同一张表时很重要) 例题1: 下面有2张表 teams表 比赛结果表:result 问题: 得出一张表:主队,客队,比赛成绩,比赛时间 方法一:子查询和连接查询混合   step1: 复制代码 代码如下: select result.id, t_name as h_name,match_time,resul

  • 关于Sequelize连接查询时inlude中model和association的区别详解

    前言 大家都知道在使用Sequelize进行关系模型(表)间连接查询时,我们会通过model/as来指定已存在关联关系的连接查询模型,或是通过association来直接指定连接查询模型关系.那么,两者各应该在什么场景下使用呢? 一. 示例准备 模型定义 首先,定义User和Company两个模型: 'use strict' const Sequelize = require('sequelize'); // 创建 sequelize 实例 const sequelize = new Seque

  • MySQL连接查询你真的学会了吗?

    1.内连接查询概要 内连接是应用程序中非常常见的连接操作,它一般都是默认的连接类型.内连接基于连接谓词,它将两张表(如A和B)的列组合在一起,产生新的结果表.内连接查询会将A表的每一行和B表的每一行进行比较,并找出满足连接谓词的组合.当连接谓词被满足,A和B中匹配的行会按列组合(并排组合)成结果集中的一行. 内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值.内连接分3种:交叉连接相等连接和自然连接. 2.交叉连接(笛卡尔积) 交叉连接(Cross Join) ,又称"

  • MySQL中连接查询和子查询的问题

    目录 多表连接的基本语法 交叉连接和笛卡尔积现象 交叉连接 笛卡尔积现象 内连接 外连接 左外连接 右外连接 全外连接 子查询 多表连接的基本语法 多表连接,就是将几张表拼接为一张表,然后进行查询 select 字段1, 字段2, ... from 表1 {inner|lift|right} join 表2 on 连接条件; 有如下两张表:部门表和员工表 交叉连接和笛卡尔积现象 交叉连接 交叉连接,又名无条件内连接/笛卡尔连接 第一张表种的每一项会和另一张表的每一项依次组合 select * f

  • MySql连接查询方式详解

    目录 1. 什么是连接查询 2. 连接查询的方式 3. 内连接 1. 等值连接 2. 非等值连接 3. 自连接 4. 外连接 1. 右外连接 2. 左外连接 5. 多张表(两张以上)连接 1. 什么是连接查询 从一张表中单独查询,称为单表查询. 跨表查询,多张表联合其来查询,称为连接查询. 2. 连接查询的方式 内连接: 等值连接 非等值连接 自连接 外连接: 左外连接(左连接) 右外连接(右连接) 当对多张表进行查询,没有任何限制的时候,返回的值是笛卡尔积 3. 内连接 1. 等值连接 查询每

  • MySQL SELECT同时UPDATE同一张表问题发生及解决

    MySQL不允许SELECT FROM后面指向用作UPDATE的表,有时候让人纠结.当然,有比创建无休止的临时表更好的办法.本文解释如何UPDATE一张表,同时在查询子句中使用SELECT. 问题描述 假设我要UPDATE的表跟查询子句是同一张表,这样做有许多种原因,例如用统计数据更新表的字段(此时需要用group子句返回统计值),从某一条记录的字段update另一条记录,而不必使用非标准的语句,等等.举个例子: 复制代码 代码如下: create table apples(variety ch

随机推荐