首页
学习
活动
专区
圈层
工具
发布

Mysql常用sql语句(8)- where 条件查询

测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 条件查询应该是作为测试平时用到最多的关键字了!!...它可以用来指定查询条件,减少不必要的查询时间 where的语法格式 WHERE 查询条件 五种查询条件 比较运算符、逻辑运算符 between and 关键字 is null 关键字 in、exist...and、&&:所有查询条件均满足才会被查询出来 or、||:满足任意一个查询条件就会被查询出来 xor:满足其中一个条件,并且不满足另一个条件时,才会被查询出来 这里有个重点,当运算符混合使用时,需要关注它们的优先级...,具体可参考这篇博文:(后面补充) 单一条件的查询栗子 一般单一条件查询用的就是比较运算符 select * from yyTest where id = 1; select * from yyTest...yyTest where age < 20; select * from yyTest where age <= 20; 多条件的查询栗子 多条件的查询都需要使用逻辑运算符,下面的栗子比较简单不展开描述

2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL中WHERE后跟着N多个OR条件会怎样。。。

    某工具在运行过程中,会产生下面的SQL进行查询,WHERE后跟了N多个条件: mysql> select * from order_line where (ol_w_id = '1' and ol_d_id...这里说的N多个,是指总共有10000个OR条件,这条SQL的长度大概将近800KB。...当WHERE查询条件里有很多OR、AND组成时,优化器判断超过内存消耗限制,则会调整SQL执行计划,变成其他执行方案,甚至可能是全表扫描。...针对本案中的SQL,更好的优化办法是找出这些OR条件的范围规律,并改写成一条更简单的SQL,类似下面这样: mysql> select * from order_line where ol_w_id =...最后再次提醒,WHERE条件后跟着N多个OR/AND条件的写法非常不可取,尤其是在用一些开发框架构造查询SQL时,尤其要注意规避这个问题,否则可能造成严重性能问题。

    2K20

    MySQL数据库,SQL的where条件提取

    = 'a'; ⼀条⽐较简单的SQL,⼀⽬了然就可以发现where条件使⽤到了[b,c,d,e]四个字段,⽽t1表的idxt1bcd索引,恰好使⽤了[b,c,d]这三个字段,那么⾛idxt1bcd索引进⾏...根据SQL,固定了索引的查询范围[(2,2,2),(8,8,8))之后,此索引范围中并不是每条记录都是满⾜where查询条件的。例如:(3,1,1)不满⾜c > 1的约束;(6,4,4)不满⾜d !...在理解以上的问题解答的基础上,做⼀个抽象,可总结出⼀套放置于所有SQL语句⽽皆准的where查询条件的提取规则: 所有SQL的where条件,均可归纳为3⼤类 • Index Key (First Key...;若where条件为 >=、>、where条件中索引相关列全部加⼊到Index Filter之中;若索引第⼀列的where条件包含 =、>=、>、<、<=...Index Key/Index Filter/Table Filter⼩结 SQL语句中的where条件,使⽤以上的提取规则,最终都会被提取到Index Key (First Key & Last Key

    2.8K10

    TP5 where数组查询(模糊查询--多个查询条件)

    有查询条件就查询,多个查询条件,只要有查询,就增加一个查询条件 一、TP5.1版本 TP运算符 SQL运算符 例子 实际查询条件 eq = $map['id'] = array('eq',100); 等效于...xor 1 = 0 exp 综合表达式 $map['id'] = array('exp','in(1,3,8)'); $map['id'] = array('in','1,3,8'); 补充说明 同 SQL...exp 的操作条件不会被当成字符串,可以使用任何 SQL 支持的语法,包括使用函数和字段名称。 ?...exp 不仅用于 where 条件,也可以用于数据更新,如: 官方查询语法:https://www.kancloud.cn/manual/thinkphp5/135182 版本 新增功能 5.0.9 比较运算增加闭包子查询支持...5.0.4 支持对同一个字段多次调用查询方法 查询表达式支持大部分的SQL查询语法,也是ThinkPHP查询语言的精髓,查询表达式的使用格式: where('字段名','表达式','查询条件');

    6.8K21

    神奇的 SQL 之 WHERE 条件的提取与应用

    今天和大家一起来看一下 SQL 生命周期中比较有意思的一个环节 给定一条 SQL,如何提取其中的 where 条件 ?...where 条件中的每个子条件,在 SQL 执行的过程中有分别起着什么样的作用 ? 前提准备   正式开讲之前了,我们先来回顾一些内容   SQL 执行流程 ?     ...= 'a' 条件   有些小伙伴可能觉得上述 WHERE 条件的抽取具有特殊性,不具普遍性,那么我们抽象出一套放置于所有 SQL 语句皆准的 WHERE 查询条件的提取规则:Index Key (First...where 条件中索引相关列全部加入到 Index Filter 之中;若第一列不包含查询条件,则将所有索引相关条件均加入到 Index Filter之中     针对 SQL:select * from...WHERE 条件的应用   SQL 语句中的 where 条件,最终都会被提取到 Index Key (First Key & Last Key),Index Filter 与 Table Filter

    2.1K10

    SQL中JOIN时条件放在Where和On的区别

    背景 SQL中JOIN子句是用于把来自两个或多个表的数据连接起来,在这个过程中可能会添加一些过滤条件。昨天有小伙伴问,如下图的这两种SQL写法查询结果是否会一样?(好像这是某一年阿里的面试题) ?...结果验证 将上面的两个表Inner Join和Left Join,过滤条件分别放在on和where中。...结论:Inner Join时过滤条件放在on和where中返回结果一致。...结论:Left Join时过滤条件放在on和where中返回结果不一致。 原因分析 可以这么理解,当两张表在Left Join时,会生成一张连接临时表,然后再将这张连接临时表返回给用户。...在Where的情况下,是在临时表生成好以后起作用,在对临时表进行过滤。此时,只要条件不为真的行,全部都过滤掉了。 — 完 —

    4K10

    SQL 语句中 where 条件后 写上1=1 是什么意思

    这段代码应该是由程序(例如Java)中生成的,where条件中 1=1 之后的条件是通过 if 块动态变化的。...例如: String sql="select * from table_name where 1=1"; if( conditon 1) { sql=sql+" and var2=value2..."; } if(conditon 2) { sql=sql+" and var3=value3"; } where 1=1 是为了避免where 关键字后面的第一个词直接就是 “and”而导致语法错误...动态SQL中连接AND条件 where 1=1 是为了避免where 关键字后面的第一个词直接就是 “and”而导致语法错误。 where后面总要有语句,加上了1=1后就可以保证语法不会出错!...IO操作,数据量越大越慢, 建议查询时增加必输项,即where 1=1后面追加一些常用的必选条件,并且将这些必选条件建立适当的索引,效率会大大提高 拷贝表 create table table_name

    4K30

    SQL命令 WHERE(一)

    指定一个或多个限制性条件的SELECT子句。...符合条件的行是那些条件表达式为真的行。 条件表达式可以是一个或多个逻辑测试(谓词)。 多个谓词可以通过AND和OR逻辑操作符链接。...在条件表达式中指定日期或时间时,可能由于SQL模式与日期或时间格式不匹配,或由于无效的日期或时间值而发生错误。 WHERE子句条件表达式必须使用与当前模式相对应的日期或时间格式。...要对列表中的多个元素使用条件表达式,必须指定这些字符。...例如,WHERE %NOINDEX Age >= 1。 离群值的谓词条件 如果动态SQL查询中的WHERE子句选择了一个非空的离群值,可以通过将离群值文字括在双括号中来显著提高性能。

    3.4K20
    领券