欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mysql进阶讲解之数据表中带OR的多条件查询

程序员文章站 2022-05-21 14:51:05
mysql进阶讲解之数据表中带OR的多条件查询 OR关键字可以联合多个条件进行查询。使用OR关键字时: 条件 1)只要符合这几个查询条件的其中一个条件,这样的记录就会被查询出...

mysql进阶讲解之数据表中带OR的多条件查询

OR关键字可以联合多个条件进行查询。使用OR关键字时:

条件

1)只要符合这几个查询条件的其中一个条件,这样的记录就会被查询出来。

2)如果不符合这些查询条件中的任何一条,这样的记录将被排除掉。

语法格式

OR关键字的基本语法格式如下:

条件表达式1OR条件表达式2[...OR条件表达式n]

OR可以连接两个条件表达式,同时可以使用多个OR关键字,以连接更多的条件表达式。

实例

实例1

使用OR关键字查询employee表中d_id为1001,或者sex为'男'的记录。SELECT语句的代码如下:

SELECT*FROMemployeeWHEREd_id=1001ORsexLIKE'男';

可将d_id为1001的记录被查询了出来,同时,sex为'男'的记录也被查询了出来。

这说明,使用OR关键字时,只要符合多个条件中的任意一个条件,就可以被查询出来。

实例2

使用OR关键字查询employee表中的记录。查询条件为num取值在(1,2,3)集合中,或者age的范围为24~26,或者homeaddress的取值中包含“厦门市”。SELECT语句的代码如下:

SELECT*FROMemployeeWHERE

numIN(1,2,3)ORageBETWEEN24AND26

ORhomeaddressLIK'%厦门市%';

结果显示,只要符合这3个条件表达式中的任意一个条件,这样的记录就会被查询出来。

OR可以和AND一起使用。当两者一起使用时,AND要比OR先运算。

实例3

使用OR和AND关键字查询employee表中的记录。SELECT语句的代码如下:

SELECT*FROMemployeeWHEREnumIN(1,3,4)ANDage=25ORsex='女';

结果显示,只要符合numIN(1,3,4)ANDage=25的记录或者符合sex='女'的记录都被显示了出来。

如果将条件的顺序换一下,将SELECT语句变成下面的情况:

SELECT*FROMemployeeWHEREsex='女'ORnumIN(1,3,4)ANDage=25;

结果显示,与前面的SELECT语句的执行结果是一样的。

这说明,AND关键字前后的条件先结合,然后再与OR关键字的条件相结合。也就是说,AND要比OR先运算。

提示

AND和OR关键字可以连接条件表达式。这些条件表达式中可以使用“=”、“>”等操作符,也可以使用IN、BETWEENAND和LIKE等关键字,而且,LIKE关键字匹配字符串时可以使用“%”和“_”等通配符。