脚本宝典收集整理的这篇文章主要介绍了mysql如何求两个查询的交集,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
MySQL求两个查询交集的方法:首先查满足单组变量键值对的流程实例id;然后将每个变量键值对作为条件都分别查出对应的流程实例id;最后对这两组流程实例id取交集,这样得到的就是想要的结果了。
更多相关免费学习推荐:mySQL教程(视频)
mysql求两个查询交集的方法:
一、项目需求:
需要获取包含一些流程变量(数量不确定,且必须都包含,不能只含其中某几个)的流程实例的实例id
二、详细说明:
1、流程变量表act_hi_VARinst
字段:PROC_INST_ID_(流程实例id)、NamE_(变量名)、TEXT_(变量值)
图1
2、现在需要查询包含变量formId=142和approveTyPE=sealApply的对应流程的实例id
如图1,只要查出红线框出的值,最终结果为
图2
三、代码实现
1、首先尝试了使用in的写法,查询结果跟图1一样(下面查询语句表达的意思是:找出包含变量值为formId=142或approveType=sealType的流程的实例id,多个变量条件只要有一个满足,就将该行取出来),该方法不可行
SELECT ahv.PROC_INST_ID_, ahv.NAME_, ahv.TEXT_ From act_hi_varinst ahv WHERE (ahv.NAME_, ahv.TEXT_) IN ( ('formId', '142'), ('approveType', 'sealApply') );
2、(可行方案)尝试使用交集(mysql本身没有交集的实现,只能自己模拟实现了)
查询思路:先查满足单组变量键值对的流程实例id,将每个变量键值对作为条件都分别查出对应的流程实例id(当前例子下,会有两组流程实例id),最终对这两组流程实例id取交集,这样得到的就是想要的结果了
SELECT PROC_INST_ID_ From ( SELECT ahv.PROC_INST_ID_ FROM act_hi_varinst ahv WHERE (ahv.NAME_, ahv.TEXT_) = ('formId', '142') UNION ALL SELECT ahv.PROC_INST_ID_ FROM act_hi_varinst ahv WHERE (ahv.NAME_, ahv.TEXT_) = ('approveType', 'sealApply') ) t group by PROC_INST_ID_ HAVING count(PROC_INST_ID_) = 2;
以上就是mysql如何求两个查询的交集的详细内容,更多请关注脚本宝典其它相关文章!
以上是脚本宝典为你收集整理的mysql如何求两个查询的交集全部内容,希望文章能够帮你解决mysql如何求两个查询的交集所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。