查询数据(select)(重点)
sql
语法
* select * from 表名; --查询所有列的记录
* select 字段1,字段2,字段3 from 表名; ‐‐ 查询字段123的记录
* DISTINCT ‐‐ 去除重复的数据 select distinct english from stu;
sql
练习
create database day15;
use day15;
create table stu(
id int,
name varchar(30),
math int,
english int,
chinese int
);
insert into stu values (1,'美美',78,93,56);
insert into stu values (2,'聪聪',18,13,16);
insert into stu values (3,'小凤',98,96,89);
insert into stu values (4,'如花',90,100,46);
insert into stu values (5,'欧阳锋',74,93,56);
insert into stu values (6,'吴彦祖',37,11,89);
insert into stu values (7,'聪大',88,77,66);
insert into stu values (8,'聪二',55,44,33);

查询语句中使用运算和别名
sql
在所有学生分数上加10分特长分。
select name,(math+10) m,(english+10) e,(chinese+10) c from stu;
统计每个学生的总分。
select name,(math+english+chinese) from stu;
使用别名表示学生分数
select name,(math+english+chinese) 总 分 from stu;


使用 where 条件过滤
sql
查询姓名为聪聪的学生成绩
select name,math,chinese from stu where name = '聪聪';
查询英语成绩大于90分的同学
select name,english from stu where english > 20;
查询总分大于200分的所有同学
select name,math+english+chinese from stu where (math+english+chinese) > 200;



where 子句中出现的运算
sql
1. > < <= >= = <> 大于、小于、大于(小于)等于、不等于
2. in 表示范围。
* select * from stu where math = 18;
* select * from stu where math in (78,18,99);
3. like 模糊查询 ‐‐ 符合模糊的条件
* select * from stu where name like '张_'; 姓张的名称(只有两个)的记录
* select * from stu where name like '张%'; 姓张的名称(张飞 张翼德 张是是是冠希)的记录。
* select * from stu where name like '%张'; 末尾是张
* select * from stu where name like '%张%'; 只要名称中包含张
4.isnull ifnull nullif判断某一个字段记录是否为空
5.and与 or或者 not非
sql
查询英语分数在 80-90之间的同学。
select * from stu where english >= 10 and english < 19;
查询数学分数为89,90,91的同学。
select * from stu where math in (89,90,91);
查询所有姓小的学生成绩。
select * from stu where name like '小%';
查询数学分>80,语文分>80的同学。
select * from stu where math > 80 or chinese > 80;




order by 对查询的结果进行排序
sql
1. 排序的语法
* select * from 表名 where 条件 order by 列名 升序/降序;
2. 升序和降序
* order by 列名 asc;(升序,默认值)
* order by 列名 desc;(降序)
3. order by 子句必须出现在select语句的末尾。
sql
对数学成绩排序后输出。
select name,math from stu order by math desc;
对总分排序按从高到低的顺序输出
select name,(math+english+chinese) as total from stu order by total desc;
对姓聪的学生成绩按照英语进行降序排序,英语相同学员按照数学降序
select name,english,math from stu order by english desc,math desc;
对姓聪的学生成绩排序输出
select name,(math+english+chinese) as total from stu where name like '聪%' order by total
desc;



