欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-03-07 16:42:48
最近遇到的一些问题总结: 1. mysql数据库同一张表做四次左连接查询数据冗余。 a. mysql数据库连接查询 b. mysql表数据去重 2. 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同一张表多次连接查询相同列赋值问题,希望对大家有所帮助