时间:2021-05-19
最近遇到的一些问题总结:
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.scoreFROM (SELECT * FROM STUDENT_SCORE WHERE test_id='11') score0 LEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id='12') score1ON score0.course = score1.courseLEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id='13') score2ON score0.course = score2.courseLEFT JOIN (SELECT * FROM STUDENT_SCORE WHERE test_id='14') score3ON 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未果。
通过给表查询添加别名将以上查询语句修改如下,解决参数赋值冲突的问题。
SELECTscore0.test_id,core0.course,score0.score,score1.score,score2.score,score3.scoreFROM (SELECT * FROM STUDENT_SCORE score0 WHERE score0.test_id=#{score0}) score0LEFT JOIN (SELECT * FROM STUDENT_SCORE score1 WHERE score1.test_id=#{score1}) score1ON score0.course = score1.courseLEFT JOIN (SELECT * FROM STUDENT_SCORE score2 WHERE score2.test_id=#{score2}) score2ON score0.course = score2.courseLEFT JOIN (SELECT * FROM STUDENT_SCORE score3 WHERE score3.test_id=#{score3}) score3ON score0.course = score3.course总结:
1、处理问题时力求正确简洁,切记多个问题混杂在一起影响问题定位与解决思路。
2、在进行多个表查询时,尽量使用别名对表进行重命名加以区分。
3、使用group by去重,后面跟哪一列对哪一列去重。
以上所述是小编给大家介绍的mybatis同一张表多次连接查询相同列赋值问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
MySQL连接查询相信大家都有所了解,连接查询是在数据库查询操作的时候经常用到的,下面就为您介绍MySQL连接查询mysql连接查询:支持多表连接对同一张表可以
一、问题给了两个各有四五十个列的表,找出他们相同的列和不同的列二、查询两个表的列,存在临时表--#a,#b都是临时表,当前连接断开后自动删除--RANK()OV
PG中有一张表记录着当前有多少连接表名:pg_stat_activity查询当前连接数selectcount(1)frompg_stat_activity;查询
前言MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。通过MERGE语句,根据一张表或多表联合查询的连接条件对另外一张表进行查
MicrosoftSQLServer里有一种computedcolumns列.这种列的值是通过一个表达式来计算,而表达式引用的是同一张表的其它列的值.打个比