全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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同一张表多次连接查询相同列赋值问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# mybatis  # 赋值  # MyBatis的嵌套查询解析  # Java的MyBatis框架中实现多表连接查询和查询结果分页  # Mybatis中连接查询和嵌套查询实例代码  # 多个  # 小编  # 在此  # 给大家  # 将以  # 都为  # 所述  # 查询结果  # 给我留言  # 感谢大家  # 重命名  # 主键  # 疑问请  # 有任何  # 数据查询  # 在网上  # score_id  # score  # int  # STUDENT_SCORE 


相关文章: 手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  如何快速登录WAP自助建站平台?  如何在万网ECS上快速搭建专属网站?  如何通过智能用户系统一键生成高效建站方案?  为什么Go需要go mod文件_Go go mod文件作用说明  模具网站制作流程,如何找模具客户?  建站之星logo尺寸如何设置最合适?  小建面朝正北,A点实际方位是否存在偏差?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  建站之星如何助力网站排名飙升?揭秘高效技巧  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  宁波自助建站系统如何快速打造专业企业网站?  山东网站制作公司有哪些,山东大源集团官网?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  建站之星伪静态规则如何正确配置?  建站之星如何开启自定义404页面避免用户流失?  如何在建站主机中优化服务器配置?  建站之星代理如何优化在线客服效率?  ,交易猫的商品怎么发布到网站上去?  如何快速打造个性化非模板自助建站?  学校建站服务器如何选型才能满足性能需求?  如何零基础在云服务器搭建WordPress站点?  如何用低价快速搭建高质量网站?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  定制建站策划方案_专业建站与网站建设方案一站式指南  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  ,怎么用自己头像做动态表情包?  C#如何序列化对象为XML XmlSerializer用法  制作销售网站教学视频,销售网站有哪些?  网站制作壁纸教程视频,电脑壁纸网站?  文字头像制作网站推荐软件,醒图能自动配文字吗?  如何设计高效校园网站?  建站主机如何选?高性价比方案全解析  ,网站推广常用方法?  建站之星如何实现五合一智能建站与营销推广?  如何快速使用云服务器搭建个人网站?  公众号网站制作网页,微信公众号怎么制作?  如何挑选高效建站主机与优质域名?  如何选购建站域名与空间?自助平台全解析  头像制作网站在线制作软件,dw网页背景图像怎么设置?  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  建站之星3.0如何解决常见操作问题?  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  网站制作软件有哪些,制图软件有哪些?  网站企业制作流程,用什么语言做企业网站比较好? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。