条件查询
条件查询
使用where子句对表中的数据筛选,结果为true的行会出现在结果集中
语法如下:
select*from表名where条件;例:select*fromstudentswhereid=1;
where后面支持多种运算符,进行条件的处理
比较运算符
逻辑运算符
模糊查询
范围查询
空判断
比较运算符
等于: =
大于: >
大于等于: >=
小于: <
小于等于: <=
不等于: != 或 <>
例1:查询编号大于3的学生
select*fromstudentswhereid>3;
例2:查询编号不大于4的学生
select*fromstudentswhereid<=4;
例3:查询姓名不是“黄蓉”的学生
select*fromstudentswherename!='黄蓉';
例4:查询没被删除的学生
select*fromstudentswhereis_delete=0;
逻辑运算符
and
or
not
例5:查询编号大于3的女同学
select*fromstudentswhereid>3andgender=0;
例6:查询编号小于4或没被删除的学生
select*fromstudentswhereid<4oris_delete=0;
模糊查询
like
%表示任意多个任意字符
_表示一个任意字符
例7:查询姓黄的学生
select*fromstudentswherenamelike'黄%';
例8:查询姓黄并且“名”是一个字的学生
select*fromstudentswherenamelike'黄_';
例9:查询姓黄或叫靖的学生
select*fromstudentswherenamelike'黄%'ornamelike'%靖';
范围查询
in表示在一个非连续的范围内
例10:查询编号是1或3或8的学生
select*fromstudentswhereidin(1,3,8);
between ... and ...表示在一个连续的范围内
例11:查询编号为3至8的学生
select*fromstudentswhereidbetween3and8;
例12:查询编号是3至8的男生
select*fromstudentswhere(idbetween3and8)andgender=1;
空判断
注意:null与''是不同的
判空is null
例13:查询没有填写身高的学生
select*fromstudentswhereheightisnull;
判非空is not null
例14:查询填写了身高的学生
select*fromstudentswhereheightisnotnull;
例15:查询填写了身高的男生
select*fromstudentswhereheightisnotnullandgender=1;
优先级
优先级由高到低的顺序为:小括号,not,比较运算符,逻辑运算符
and比or先运算,如果同时出现并希望先算or,需要结合()使用