```msyql

---【AND 操作符】
为了通过不止一个列进行过滤,可以使用and操作符对where子句附加条件,


select prod_id,prod_price,prod_name
from products
where vend_id=1003 and prod_price <=10;

【分析】此sql语句检索商品的供应商编号,并且价格小于等于10的所有产品的名称和价格,这条select语句中的where子句包含来那个条件,并且用and 关键字链接他们,
and 指示DBMS 只返回满足所有给定条件的行。如果某个商品,供应商,1003制造,价格高于10就不会检索它。

检测的结果是:

prod_id    |     prod_price    |    prod_name

fb                 |    2                    |    sangsing

hb                |    2                    |    sa
opb              |    5                    |    sa
kkb              |    2.3                   |    sang

and 用在where子句中的关键字,用来指示检索满足所有给定条件的列

使用and 还可以添加 多个过滤条件,就是在后面添加一个一个的and

---【OR 操作符】

or操作符和and操作符不同,它指示MySQL检索匹配任一条件的行
如下select语句

select prod_name,prod_price
from products
where vend_id =1002 or vend_id=1006;

or 检索的时候,只是检索其中的一条,只要有一个成立就会查询出来结果,如果都没有的话则查询没有数据
and 是必须所有的条件都要成立才可以,所以使用and或者or要根据实际情况来使用。

--【计算次序】
where可以包含任意数目的and和or操作符,允许两者结合已进行复杂的高级过滤
使用MySQL语句查询下面的数据:
假如需要列出价格为大于等于10 并且由1002或者1003 制造的所有产品,下面的select语句使用and 和or操作符的组合建立了一个where子句进行数据查询

select prod_name,prod_price
from products
where vend_id =1002 or vend_id =1003 and prod_pricce >=10;

查询结果是:
prod_name    |    prod_price

bird                  |    13
bold                 |    14
ayrd                  |    8
awrd                  |    5
oldd                  |    33

通过上面的查询结果,我们可以看到查询的结果中有两条数据是小于10的,这是因为什么呢?
!!!原因就是在于计算机的次序。
【在处理or操作符前,会优先处理and操作符,当sql看到上述的where子句时,它理解的就是由供应商1003制造的任何价格为10以上的产品,或者由供应商1002制造的任何产品,而不管价格如何,

换句话说,就是由于AND 在计算机中的优先级最高,操作符被错误组合了。】

这种问题的解决方法就是使用小括号把对应的分组给括起来。


select prod_name,prod_price
from products
where (vend_id =1002 or vend_id =1003) and prod_pricce >=10;


查询结果是:
prod_name    |    prod_price

bird                  |    13
bold                 |    14
oldd                  |    33

在where子句中使用圆括号,任何时候使用具有and或者or 操作的where子句,都应该使用圆括号明确的进行分组操作符,不要过分的依赖默认计算机次序,即使它是你想要的东西也是如此,使用圆括号,没有任何坏处,它可以消除歧义。

---【in操作符】

圆括号在where子句中还有另外一种用法,in操作符用来指定条件范围,范围中的每个条件都可以进行匹配,in 取合法值的由逗号分隔的清单,全都括在圆括号中。


select prod_name,prod_price
from products
where vend_id in(1002,1003)
order by prod_name;

查询结果是:
prod_name    |    prod_price

bird                  |    13
bold                 |    14
ayrd                  |    8
awrd                  |    5
oldd                  |    33

in 代表在一个合法的区间里面,只要在这个区间里面都是合法的值,所以如果要取区间的值就用in这个合法的语法来进行取值。

in 操作符和不加集合的or操作符完成相同的功能。
---【使用in操作符的优点】
-在使用长的合法选项清单时,in操作符的语法更清楚并且更加直观
-在使用in时,计算的次序更容易管理,因为使用的操作符更少
-in操作符一般比or操作符清单执行更快速高效
-in的最大优点是可以包含其他select语句,使得能够更动态地建立where子句!!!

--【not操作符】
where子句中的not操作符,有且只有一个功能,那就是否定它之后所跟的条件。
--not where 子句 用来否定后跟条件的关键字。
为了证明一下商品ID不在1002 和1003中,编写如下代码:


select prod_name,prod_price
from products
where vend_id not in (1002,1003)
order by prod_name;

prod_name    |    prod_price

d                  |    13
ld                 |    14
rd                  |    8
wrd                  |    5
ldd                  |    33

not的优势,在复杂的高级查询中会很有用处,例如在和in操作符联合使用时,not使找出与条件列表不匹配的行非常简单。

```

02-13 13:17