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

博客介绍了在MyBatis中遇到的同一张表进行多次左连接查询时,由于列名相同导致赋值重复的问题。通过分析数据库查询和MyBatis的XML配置,提出了在resultMap中使用<collection>和<association>尝试解决,但未成功。最终解决方案是通过为表查询添加别名来区分列,避免赋值冲突。总结强调了解决问题时保持清晰思路的重要性,以及在多表查询中使用别名的实践建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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_id与score2.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去重,后面跟哪一列对哪一列去重。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值