文档章节

Mybatis联合查询记录,左连接参数操作

o
 osc_w9s1w4o0
发布于 2019/04/02 13:29
字数 387
阅读 8
收藏 0

精选30+云产品,助力企业轻松上云!>>>

公司业务需求要做个列表的排序

而实际排序的字段不再本库中,需要跨库去拿到字段,因为是微服务体系架构,不可能Left join跨库的表,所以决定调用一次跨服务的API拿到排序相关的对象,里面包含需要排序的列

一块拿到sql中进行排序(因为order by比较方便。。。。)

然后开始出现了bug,我把跨服务拿到的对象存成List集合,需要在sql中左连接才能使用里面的字段,但是直接这样写就会出现bug:

ScheduleDictionary

left join

(select O.Id AS OrgId,O.`Code`,O.`Name` from #{param.orgModels} O)

AS Org on ScheduleDictionary.OrganizationId=Org.OrgId

bug的日志打印大约是这样:

You have  an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near'_binary'??\0sr\0java.util.ArrayListx??↔??a?♥\0I\0sizexp\0\0\0w\0\0\0t\0
google了一下,只有一个问题是跟这个相关的,所以决定记录一下把,
问了下领导,这样直接left join一个list集合是不行的,需要拆开:

拆开的办法是使用union join 例如:select 1 as id,tt as name union join select 2 as id ,dd as name .....最后拼成一张表,
而我传过去的是个List肯定要用foreach循环

就这样就可以把它当作一张表去与主表连接了,

同样也可以拿到 主键或者code去下面进行排序操作了,

 









o
粉丝 0
博文 500
码字总数 0
作品 0
私信 提问
加载中
请先登录后再评论。

暂无文章

渗透测试的概念和实战

目录 1. 前言 2. 常见web安全漏洞 3. 思路 3.1渗透测试思路 3.2黑客攻击思路 4. 暴力破解 4.1谷歌黑语法 4.1.1 黑语法inurl:搜索url包含指定字符串 4.1.2 黑语法intitle:搜索网页中的标题名...

六道木
42分钟前
19
0
Nginx搭建

Web服务器 放置网站文件,全世界浏览 可以放置数据文件,让全世界可以下载。 Nginx官方网站www.nginx.org #rz nginx-1.11.6.tar.gz #ls #rpm -q zlib-devel pcre-devel #yum –y install zli...

osc_fnto2dbd
54分钟前
14
0
如何在1分钟内CSDN收益1000万,走上人生巅峰?!

事情的起因源于前几日CSDN专栏作者群中有位同志自曝收益:426584.46元(不用数了42万+,未证实是否属实),瞬间刷屏。 那么作为一位普通的技术分享者,是否有机会利用开源项目短时间内赢取白...

osc_8db3mwb5
55分钟前
23
0
【java基础(五十)】为什么要使用泛型程序设计

从Java程序设计语言1.0版发布以来,变化最大的部分就是泛型。致使Java SE 5.0中增加泛型机制的主要原因是为了满足1999年制定的最早的Java规范需求之一(JSR 14)。专家组花费了5年左右的时间...

osc_qcm2mqmy
57分钟前
20
0
如何将Unix时间戳转换为DateTime,反之亦然? - How can I convert a Unix timestamp to DateTime and vice versa?

问题: There is this example code, but then it starts talking about millisecond / nanosecond problems. 有此示例代码,但随后开始谈论毫秒/纳秒问题。 The same question is on MSDN, ......

javail
57分钟前
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部