DQL介绍
DQL : Data Query Language,数据查询语言,主要用于查询表。
它通常用来从一张表或者多张表(视图或者子查询等)中按指定的条件筛选出某此记录。涉及到的命令有select。
语法 :
select 列限定 from 表限定 where 行限定;
示例代码 :
create table teacher(
id int,
name
varchar(30)
);
insert into teacher (id,name) values (1,‘张老师’);
insert into teacher (id,name) values (2,‘王老师’);
最简单粗暴的一个DQL :
select * from teacher;
会查询到teacher表中所有的数据
如果想查看所有行的name
select name from teacher;
如果想查看id为1的讲师姓名
select name from teacher where id = 1;
条件判断
上面一个简单的DQL查询时,我们使用到了where行限定,后面写的是id=1
但是如果这一个条件不满足我们判断的条件呢?比如 id=1 且 name=’张老师’ 就怎么怎么样
所以我们的条件判断,是用于where后面的
示例代码 :
create table student(
id int,
name
varchar(30),
score decimal(18,2)
);
insert into student(id,name,score) values (1,‘张三’,99.2);
insert into student(id,name,score) values (2,‘李四’,97.9);
insert into student(id,name,score) values (3,‘王五’,98);
insert into student(id,name) values (4,‘赵六’);
insert into student(id,name,score) values (5,‘小明’,98);
and
且,和,的意思,一般用于 必须符合两个添加的判断,等同于java中的 &&
语法 :
select 列限定 from 表限定 where A表达式 and B表达式;
如 : 查询学生表中,name是张三且成绩大于90分
select * from student where name=‘张三’ and score > 90;
只会查询出符合两个条件的学生
or
或的意思,一般用于 符合一个添加判断的情况下,等同于java中的 ||
语法 :
select 列限定 from 表限定 where A表达式 or B表达式;
如 : 查询学生表中,name是张三 或 成绩大于90分
select * from student where name=‘张三’ or score > 90;
只要符合两个条件中的任何一个条件,就可以
注意 : 如果 一个语句中,同时出现了and和or的话,and优先级高
between and
在…之间
语法 :
select 列限定 from 表限定 where 列名 between 值1 and 值1;
如 : 查询学生表中 成绩在98到100之间 (包含98和100)
select * from student where score >= 98 and score<=100;
等价于
select * from student where score between 98 and 100;
In
在指定数据中
语法 :
select 列限定 from 表限定 where 列名 in(值1,值2…);
如 : 给出一个数据集合(1,3,10,20),获取学生id在这个数据集合中的学生信息
select * from student where id in (1,3,10,20);
模糊查询like
我们经常会用到搜索功能,比如百度,搜索功能实现,就是使用like模糊查询技术点
其中 % 匹配任意个数的任意字符
_ 匹配单个任意字符
语法 :
select 列限定 from 表限定 where 列名 like ‘值’ ;
如 : 把name中,把姓张的查询出来
select * from student where name like ‘张%’;
如 : 把 name中,姓名有两个字的查询出来
select * from student where name like ‘__’;
Order by 排序
排序,望文知意,能够让我们查询的数据进行排序展示
语法 :
select 列限定 from 表限定 order by 列名 asc/desc;
Asc : 升序
Desc : 降序
如 : 查询所有学生信息,以成绩降序
select * from student order by score desc;
如 : 查询所有学生信息,按成绩降序,如果成绩相同,按照id升序
select * from student order by score desc , id asc;
Limit
限制条数,通常和order by一起使用,因为我们使用排序之后,再去获取前几条数据,比较有价值,比如成绩前三名
语法 :
select 列限定 from 表限定 limit 条数;
select 列限定 from 表限定 limit 开始值(不包含) ,条数;
如 : 查询学生表,分数前三名的信息
select * from student order by score desc limit 3;
如 : 查询学生表,分数第二名和第三名
select * from student order by score desc limit 1,2;