sql查询语句

1.建表:

create table students(
	id int,   -- id编号
	name varchar(20), -- 姓名
	chinese int,  -- 语文
	english int, -- 英语
	math int -- 数学
);

2.填入数据:

insert into student(id,name,chinese,english,math) values(1,'行哥',89,78,90);
insert into student(id,name,chinese,english,math) values(2,'潘金莲',67,53,95);
insert into student(id,name,chinese,english,math) values(3,'凤姐',87,78,77);
insert into student(id,name,chinese,english,math) values(4,'旺财',88,98,92);
insert into student(id,name,chinese,english,math) values(5,'白小黑',82,84,67);
insert into student(id,name,chinese,english,math) values(6,'白小黄',55,85,45);
insert into student(id,name,chinese,english,math) values(7,'范蹦蹦',75,65,30);

3.查询语句:

1)查询表中所有学生的信息。

 

select * from students;


2)查询表中所有学生的姓名和英语成绩。

 

SELECT NAME,english FROM students;

 
3) 过滤表中重复数据。(去重的关键字 distinct)

 

SELECT DISTINCT * FROM students;


4)统计每个学生的总分

 

SELECT *,(chinese+english+math) 总成绩 FROM students;

 

 

 
5)在所有学生总分数上加10分特长分。

 

SELECT *,(chinese+english+math)+10 总成绩 FROM students;


6)使用别名表示学生分数。
 

SELECT 
  id '编号',
  NAME '姓名',
  chinese '语文成绩',
  english '英语成绩',
  math '数学成绩' 
FROM
  students ;


7)查询姓名为行哥的学生成绩

 

SELECT * FROM students WHERE NAME = '行哥';

 

 
8)查询英语成绩大于90分的同学

 

SELECT * FROM students WHERE english > 90;


9)查询总分大于200分的所有同学

 

SELECT *,(chinese+english+math) 总成绩 FROM students WHERE (chinese+english+math)>200;

 
10)查询英语分数在 80-90之间的同学。

 

SELECT * FROM students WHERE english BETWEEN 80 AND 90;

 
11)查询数学分数为89,90,91的同学。

 

SELECT * FROM students WHERE math IN(89,90,91);

 
12)查询所有姓白的学生英语成绩。

 

SELECT * FROM students WHERE NAME LIKE '白%';


13)查询数学分>80并且语文分>80的同学

 

SELECT * FROM students WHERE math > 80 AND chinese > 80;

 
14)查询英语>80或者总分>200的同学

 

SELECT 
  *,
  (chinese + english + math) 总成绩 
FROM
  students 
WHERE english > 80 
  OR (chinese + english + math) > 200 ;

 
15)对数学成绩升序排序

 

SELECT * FROM students ORDER BY math ASC

 
16)对总分降序排序,然后再按数学从高到低的顺序输出

 

SELECT 
  *,
  (chinese + english + math) 总成绩 
FROM
  students 
ORDER BY math DESC,
  总成绩 DESC 

 
17)对姓白的学生成绩排序输出(排序规则自己定义)

 SELECT * FROM students WHERE NAME LIKE '白%' ORDER BY chinese DESC;

 

 

18)查询数学成绩大于等于平均分的所有学生信息

一)查询数学平均分是多少

SELECT AVG(math) FROM student3; -- 79.5000


二)查询大于数学平均分的学生信息

SELECT 
    *
FROM 
    student3
WHERE 
    math > 79.5000;


    三)前两步合一

 SELECT * FROM students WHERE math > (SELECT AVG(math) FROM students);

 

 

19)查询出英语成绩最高分的学生信息

        

一)查询最高分是多少

SELECT  MAX(english) FROM students;


 二)查询最高分是这个成绩的学生信息

SELECT 
    NAME '姓名',
    age '年龄',
    address '地址', 
    english '英语成绩' 
FROM 
    students  
WHERE 
    第一步里得出的最高成绩


三)两步合一

 SELECT * FROM students WHERE english = (SELECT MAX(english) FROM students);

 

 

20)模糊查询出学生姓名中第二个字是金的学生信息

        DQL语句之 where条件后面加入模糊查询 ---关键字 like
                select 字段列表 from 表名 where 字段名称 like '%xxx%' ;
                %:代表任何多个字符或者某个字符   (使用居多):网站门户系统---"搜索商品" ,模糊搜索
                _:代表某个单个字符

 SELECT * FROM students WHERE NAME LIKE "_金%";

 

21)查询出英语成绩平均分是多少

         avg(字段名称): 查询这个字段中平均值 

 SELECT AVG(english) FROM students

 

 

22)查询出数学总分是多少

        sum(字段列表):求和函数

 SELECT SUM(math) FROM students

 

 

23)查询学生表中有多少条记录

        count(字段名称):查询表中记录 ,字段名称使用都是id,非业务字段

 SELECT COUNT(id) FROM students

 

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DIO______________

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值