mysql--使用left join条件查询时加where条件的问题
场景:为一个活动添加指导文件,每一个活动会对应多种指导文件类型,进入每一个活动的设置指导文件页面后所呈现的指导文件类型相同,查询时,使用指导文件类型表LEFT JOIN指导文件表,要求指导文件类型全部列出,已经填写的指导文件项在其后标出,而指导文件表只有一张,所有活动、指导文件类型的数据都在这里,要通过不同的活动进行筛选,一开始的sql语句是这样的:
SELECT `zxb_guidebooks_type`.*, `zxb_leading_guidebooks`.*, `zxb_guidebooks_type`.`id` AS `type_id`, `zxb_leading_guidebooks`.`id` AS `guide_id` FROM `zxb_guidebooks_type` LEFT JOIN `zxb_leading_guidebooks` ON zxb_leading_guidebooks.type_id=zxb_guidebooks_type.id WHERE (zxb_guidebooks_type.status=1) AND (zxb_guidebooks_type.pid!=0) AND (zxb_leading_guidebooks.leading_id=2) ORDER BY `p_order` LIMIT 20
查询后发现,返回的结果为EMPTY SET,查阅资料后原来,数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户,where条件会在临时表生成好后,再对临时表的结果进行过滤,于是就出现了EMPTY SET的情况,LEFT JOIN在加上WHERE条件后就会转变为join,想要解决这个问题有两种办法
一、最简单的方法,可以把该WHERE条件写在ON之后
SELECT `zxb_guidebooks_type`.*, `zxb_leading_guidebooks`.*, `zxb_guidebooks_type`.`id` AS `type_id`, `zxb_leading_guidebooks`.`id` AS `guide_id` FROM `zxb_guidebooks_type` LEFT JOIN `zxb_leading_guidebooks` ON zxb_leading_guidebooks.type_id=zxb_guidebooks_type.id and zxb_leading_guidebooks.leading_id=2 WHERE (zxb_guidebooks_type.status=1) AND (zxb_guidebooks_type.pid!=0) ORDER BY `p_order` LIMIT 20
二、将有where条件的LEFT JOIN作为一个临时表,然后用指导文件类型表,再LEFT JOIN这个临时表,这样无论where怎么变也不会影响最终结果了
SELECT a.*,tmp.* FROM a LEFT JOIN (SELECT a.*,b.* FROM a LEFT JOIN b ON a.b_id=b.id WHERE b.dd=1 AND a.status=1) as tmp WHERE a.status=1;
mysql--使用left join条件查询时加where条件的问题的更多相关文章
- 一步一步跟我学习lucene(18)---lucene索引时join和查询时join使用演示样例
了解sql的朋友都知道,我们在查询的时候能够採用join查询,即对有一定关联关系的对象进行联合查询来对多维的数据进行整理.这个联合查询的方式挺方便的.跟我们现实生活中的托人找关系类似,我们想要完毕一件 ...
- PL/SQL Developer 使用中文条件查询时无数据的解决方法
PL/SQL Developer 使用中文条件查询时无数据,这是由于字符集的不一致导致的. 执行以下sql命令:select userenv('language') from dual; 显示:SIM ...
- PL/SQL Developer 使用中文条件查询时无数据的解决方法(转)
原文地址: PL/SQL Developer 使用中文条件查询时无数据的解决方法 PL/SQL Developer 使用中文条件查询时无数据,这是由于字符集的不一致导致的. 执行以下sql命令:sel ...
- util-C# 复杂条件查询(sql 复杂条件查询)查询解决方案
ylbtech-funcation-util: C# 复杂条件查询(sql 复杂条件查询)查询解决方案 C# 复杂条件查询(sql 复杂条件查询)查询解决方案 1.A,Ylbtech.Model返回 ...
- SQL中join连接查询时条件放在on后与where后的区别
数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户. 在使用left jion时,on和where条件的区别如下: 1. on条件是在生成临时表时使用的条 ...
- Entity Framework Code First 在Object Join Linq查询时出现全表查询的语句。
最近一个项目,使用微软的Entity Framework的ORM框架的项目,部署到现场后,出现了系统缓慢,多个客户端的内存溢出崩溃的问题. 打开了SQL Server Profiler(SQL Ser ...
- angularJS 条件查询 品优购条件查询品牌(条件查询和列表展示公用方法解决思路 及 post请求混合参数提交方式)
Brand.html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> &l ...
- MySql数据库,对varchar类型字段str进行where str=0条件查询时,查询结果是什么
在用MySQL查询数据的时候,遇到了一个奇怪的问题.用一个varchar类型的字符串str,作为条件与0比较时,会查str不为0的数据. 比如:SELECT id, idnumber from hr_ ...
- Left Join on 多条件查询时,条件过滤的问题
例如:A Left Join B on (...) on 后面的条件是对B数据的过滤,如果要对A的数据或者联合之后的数据集进行过滤,则要把过滤条件放在where子句中
随机推荐
- selenium+chromdriver 动态网页的爬虫
# 获取加载更多的数据有 2 种方法# 第一种就是直接找数据接口, 点击'加载更多' 在Network看下, 直接找到数据接口 # 第二种方法就是使用selenium+chromdriver # se ...
- iview admin template 基础模板架子
https://github.com/iview/iview-admin/tree/template
- C# MP3播放帮助类
本文为原创文章如需转载请注明出处: /// <summary> /// ************************************************* /// 类名:M ...
- Android UI性能测试——使用 Systrace 查找问题
一 官方文档翻译 官文地址:https://developer.android.com/studio/command-line/systrace systrace命令允许您在系统级别上收集和检查所有运 ...
- 一道值得思考的fork()面试题
程序如下,判断输出多少个'_' ./a.out int main(){ ; i < ; ++i){ fork(); printf("_"); } } 熟悉fork的话,这里很 ...
- Web_Servlet—— Servlet生命周期
第4章 Servlet生命周期(重要) 4.1 Servlet生命周期概述 1,应用程序中的对象不仅在空间上有层次结构的关系,在时间上也会因为处于程序运行过程中的不同阶段而表现出不同的状态和不同的行为 ...
- IntegerCache缓存占用堆、栈、常量池的问题,自动拆装箱的基本概念,Integer==int时的问题说明
原创声明:作者:Arnold.zhao 博客园地址:https://www.cnblogs.com/zh94 先普及一个基本概念:Java中基本数据类型的装箱和拆箱操作 自动装箱 在JDK5以后,我们 ...
- Vue中使用echarts,ajax请求的远程数据赋值给图表不刷新的问题和解决办法
问题: vue-cli搭建的项目,在mounted钩子函数里面创建echarts图表,本地模拟数据可以正常显示,但是当将ajax请求的远程数据赋值给图表时,图表并不会刷新. 解决办法: 刚开始以为是v ...
- 直径问题 Diameter Problems
2019-11-03 21:37:59 一.Diameter of Binary Tree 问题描述: 问题求解: 解法一.第一反应是树上动归,每个节点保存一下左右的最大深度,最后以每个节点作为中枢计 ...
- 浏览器与DNS解析过程
浏览器解析 1.地址栏输入地址后,浏览器检查自身DNS缓存 地址栏输入chrome://net-internals/#dns 查看. 2.浏览器缓存中未找到,那么Chrome会搜索操作系统自身的DNS ...