1.1AND操作符
如果需要通过多个列过滤数据,那么可使用AND操作符给where子句附加条件
SELECT 输出列名1,输出列名2……
FROM 表
WHERE 过滤列名1,过滤列名2,……;
上述表示将vend_id=1001和prod_price=5.99作为数据过滤条件
补充:当每新增一个过滤条件时,便增加一个AND
1.2 OR操作符
OR操作符是匹配任意一条件,相比较AND(AND是匹配同时满足所有过滤条件)
SELECT 输出列名1,输出列名2……
FROM 表名
WHERE 过滤列名1 OR 过滤列名2 OR 列名3……;
1.3计算次序
当组合AND和OR时,那么就会产生先执行那个的顺序问题。那么MySQL定义AND的优先级要比OR的优先级高,为了解决这种可能存在的未知的错误,最好的办法是使用圆括号明确地分组相应的操作。
SELECT 输出列名1,输出列名2……
FROM 表名
WHERE (过滤列名1 OR过滤列名2)AND 过滤列名3;
1.4 IN操作符
圆括号在where子句中还有另外一种用法。IN操作符用来指定条件范围中的每个条件都可以进行匹配,IN取值合法值的由逗号分隔的清单,这种用法与OR相同
SELECT 输出列名1,输出列名2…… FROM 表名 WHERE 过滤列名 IN (取值1,取值2……);
补充:虽然说IN的用法和OR的用法相同,但是相比较来说,IN执行更快
1.4 NOT操作符
WHERE子句中的NOT操作符有且只有一个功能,那就是否定它之后的任何条件
SELECT 输出列名1,输出列名2…… FROM 表名 WHERE 过滤列名1 NOT 否定的条件;
上面SQL语句表示的意思是:输出vend_id不为1001,1003的所有满足该条件的行
MySQL支持使用NOT对IN,BETWEEN和EXISTS子句取反