MySql学习(四)

查询数据(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;
相关推荐
2301_815279522 小时前
JavaScript中快速清空数组的多种方式及其性能差异
jvm·数据库·python
START_GAME2 小时前
SQL Server 还原 .bak 文件(SSMS 图形界面法)
运维·服务器·数据库
suliqiang2 小时前
MySQL数据库性能优化实战:系统性能提升100%的完整指南
数据库·mysql·性能优化
鸿儒5172 小时前
中医学习首篇笔记
笔记·学习·中医
数厘2 小时前
2.20 sql基础聚合函数(COUNT、SUM、AVG、MAX、MIN)
数据库·sql·oracle
优化控制仿真模型2 小时前
【26年6月四级】英语四级2015-2025年12月真题及答案+高频核心词汇1500个pdf电子版
经验分享·pdf
苏渡苇2 小时前
Redis 版本演进、新特性与协议那些事儿
数据库·redis·缓存·开源协议·redis版本·redis新特性
鬼蛟2 小时前
Nacos
数据库·redis·缓存
倔强的石头_2 小时前
NFS网络文件系统下企业级数据库安装排障实战:环境变量失效与权限问题的深度解析
数据库