mysql-数据查询语句-单表

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 1、查询指定列 select sno,sname from student;image.png2、查询全部列select * from sc;image.

1、查询指定列

 select sno,sname from student;
img_79a6b0b9dec569eb7f9a25f3e031cb2f.png
image.png

2、查询全部列

select * from sc;
img_9d6970a16b2b448612b98b19fe52ea59.png
image.png

3、查询经过计算的值

select sname,2018-sage from student;  //目标列是表达式

select sname,'Year of birth:',2018-sage,lower(sdept) from student; //目标表达式可以是字符串常量、函数等

 select sname NAME,'Year of birth:' BIRTH, 2018-sage BIRTHDAY,lower(sdept) DEPARTMENT from student; //别名

select 子句的目标列表达式不仅可以是属性列,还可以是表达式


img_f13816e97efb1412774dcd5406e586ed.png
image.png

目标列 不仅可以是算术表达式,还可以是字符串常量、函数等。


img_985ff8d7141c35548ef38113daaac1cd.png
image.png

还可以通过指定别名来改变查询结果的列标
img_0acc36a6578b530b3652be6233d2e9ef.png
image.png

4、消除重复的行

select distinct sno from sc; //distinct 表示去重
select [all] sno from sc;  //如果没有指定distinct,则默认是all
img_8d6f93f2e642ac4003f5ff93c16a282d.png
image.png

条件查询

5、比较大小

用于进行比较的运算符一般包括 =,>,<,>=,<=,!=,!>,!<。最后两个分别是不大于,不小于。

//查询计算机科学系全体学生的名单
select sname from student where sdept='CS';
img_96288de163ee855f3dc8387bcd0cb665.png
image.png
//查询所有年龄在20岁以下的学生姓名及其年龄
select sname,sage from student where sage<20;
img_b53a52c4a390a494f417be2f1ec2652e.png
image.png
//查询考试成绩不及格的学生的学号
select distinct sno from sc where grade<60;
img_e12a25daaaa7a6d07379058ea3a5b8ee.png
image.png

6、确定范围

谓词 between…and… 和 not between…and… 可以用来查找属性值在(或不在)指定范围内的无组,其中between后是范围的下限(即低值),and 后是范围的上限(即高值)。

//查询年龄在20~30岁(包括20岁和30岁)之间的学生的姓名、系别和年龄。
select sname,sdept,sage from student where sage between 20 and 30;
img_c140c334936198c7ff877bfc7a45de1b.png
image.png
//查询年龄不在20~30岁之间的学生姓名、系别和年龄。
 select sname,sdept,sage from student where sage not between 20 and 30;
img_5629cf08d99018b1f626b05227618007.png
image.png

7、确定集合

谓词 in 和 not in 可以用来查找属性值属于或不属于指定集合的元组

//查询计算机科学系(CS)、数学系(MA)和信息系(IS)学生的姓名和性别。
 select sname,ssex from student where sdept in('CS','MA','IS');
img_db3efeb3c7dce293077f0e75512c4142.png
image.png
//查询既不是计算机科学系(CS)、数学系(MA),也不是信息系(IS)学生的姓名和性别。
select sname,ssex from student where sdept not in('CS','MA','IS');
img_adc9f575538b5c4dfe5cabc5d2c24ad3.png
image.png

8、字符匹配

谓词 like 可以用来进行字符串的匹配。%(百分号)代表任意长度(长度可以为0)的字符串。_(下划线)代表任意单个字符。

//查询学号为201215121的学生的详细情况
select * from student where sno like '201215121';
//上式可以等价为
select * from student where sno='201215121';

如果 like 后面的匹配串不含通配符,则可以用 = (等于)运算符取代 like 谓词,用 != 或 <>(不等于)运算符取代not like 谓词。


img_025bfd75daa6f165f7a1ce7ba0db0789.png
image.png
//查询所有姓刘的学生的姓名、学号和性别
select sname,sno,ssex from student where sname like '刘%'; //%代表任意长度
img_2709767009b0a9c4c984de776817e321.png
image.png
//查询姓“欧阳”且全名为三个汉字的学生的姓名。
select sname,sno from student where sname like '欧阳_'; 
//    _ 一般用于查询明确长度的字符匹配
img_7cee28e1a6289308dd3369efc49a6384.png
image.png
//查询名字中第二个字为“阳”的学生的姓名和学号
 select sname,sno from student where sname like '_阳%';
img_0ab25f8475acd1f96497e27b32e07e35.png
image.png
//查询所有不姓刘的学生的姓名、学号和性别
select sname,sno,ssex from student where sname not like '刘%';
img_551de8db786d164ea30c4c74ca1449d5.png
image.png
//查询DB_Design课程的课程号和学分
select cno,ccredit from course where cname like 'DB\\_Design';

如果条件里面包含一些特殊的字符,那么就要进行转义了,在mysql里面是在特殊字符前面加 \(反斜杠)进行转义。


img_57568fb4045b117fc2b4919bed536c66.png
image.png
//查询以“DB_开头,且倒数第三个字符为 i 的课程的详细情况”
select * from course where cname like 'DB\_%i__'; 
img_ab37e4dbbe92a6c158f7f5c53bb0674f.png
image.png

9、涉及空值的查询

//查询缺少成绩的学生的学号和相应的课程号
select sno,cno from sc where grade is null; 
//注意:这里的 “is” 不能用等号(=)来代替
img_f9454bf1aa7a6d6495d147b0d068ccc0.png
image.png
//查询所有有成绩的学生学号和课程号
select sno,cno
    -> from sc
    -> where grade is not null;
img_7fa7d661c0c4f2ea0f5096d16685e97b.png
image.png

10、多重条件查询

逻辑运算符 and 和 or 可用业连接多个查询条件。and 的优先级高于 or , 但是可以用括号改变优先级。

//查询计算机科学系(CS)、数学系(MA)和信息系(IS)学生的姓名和性别
mysql> select sname, ssex from student
    -> where sdept='CS' OR sdept='MA' or sdept='IS';
// in 谓词实际上是多个or运算符的缩写
img_aca43796c5fcb28e2d2cc06a6a3395c1.png
image.png
//查询计算机科学第年龄在20岁以下的学生姓名
mysql> select sname
    -> from student
    -> where sdept='CS' and sage<20;
img_9ffd8c3a875eb4d3c2c712b418f04a13.png
image.png

10、order by子句

用order by 子句对查询结果一个或多个属性列的升序(asc)或降序(desc)排列,默认值为升序。

//查询选修了3号课程的学生的学号及其成绩,查询结果按分数的降序排列。
mysql> select sno,grade
    -> from sc
    -> where cno='3'
    -> order by grade desc;
img_d18583b8aa806c1649d0bd427de7e382.png
image.png
查询全体学生情况,查询结果按所在系的系号升序排列,同一系的学生按年龄降序排列
mysql> select *
    -> from student
    -> order by sdept,sage desc;
img_73edb8933c856ab7dd6bccfce6f821a4.png
image.png

11、聚集函数

//查询学生总人数
mysql> select count(*)
    -> from student;
img_11dd0ecf962177aa24b30f1b8cb33bed.png
image.png
//查询选修了课程的学生人数
mysql> select count(distinct sno)
    -> from sc;
img_6990035dd86e88b21d6948afe4675fff.png
image.png
//计算选修1号课程的学生平均成绩
mysql> select avg(grade)
    -> from sc
    -> where cno='1';
img_104cc2bdd8230c790a50a48b4e32cba1.png
image.png
//查询选修1号课程的学生最高分
mysql> select max(grade)
    -> from sc
    -> where cno='1';
img_b8de5703640d3838afdbf5c8a8380322.png
image.png
//查询学生201215012选修课程的总学分数
mysql> select sum(ccredit)
    -> from sc,course
    -> where sno='201215012' and sc.cno=course.cno;

img_d7f312a9dae50ba4c557d55c2b9a09b4.png
image.png

当聚集函数遇到空值时,除 count( ) 外,都跳过空值而只处理非空值。count() 是对元组进行计数,某个元组的一个部分列取空值不影响count的统计结果
注意: where 子句中是不能用聚合函数作为条件表达式的。聚集函数只能用于select 子句和 group by 中的 having 子句。

12、group by 子句

group by 子句将查询结果按某一列或多列的值分组,值相等的为一组。分组后聚集函数将作用于每一个组,即每一组都有一个函数值。

//求各个课程号及相应的选课人数
mysql> select cno,count(sno)
    -> from sc
    -> group by cno;
img_dba5b7b3daf9254026e5e600e5da8442.png
image.png

如果分组后还要求按一定的条件对这些级进行筛选,最终只输出满足指定条件的组,则可以使用having短语指定筛选条件。

//查询选修了三门以上课程的学生学号
mysql> select sno
    -> from sc
    -> group by sno
    -> having count(*)>3;
img_b5299ed31ce249a370dc8a85f50c333d.png
image.png

where 子句与 having 短语的区别在于作用对象不同。where 子句作用于基本表或视图,从中选择满足条件的元组。having 短语作用于组,从中选择满足条件的组。

//查询平均成绩大于等于90分的学生学号和平均成绩
mysql> select sno,avg(grade)
    -> from sc
    -> group by sno
    -> having avg(grade)>90;
img_4f9372a67125d91316567966b618ab47.png
image.png
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
安全 关系型数据库 MySQL
如何将数据从MySQL同步到其他系统
【10月更文挑战第17天】如何将数据从MySQL同步到其他系统
218 0
|
28天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
132 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
10天前
|
SQL 关系型数据库 MySQL
mysql分页读取数据重复问题
在服务端开发中,与MySQL数据库进行数据交互时,常因数据量大、网络延迟等因素需分页读取数据。文章介绍了使用`limit`和`offset`参数实现分页的方法,并针对分页过程中可能出现的数据重复问题进行了详细分析,提出了利用时间戳或确保排序规则绝对性等解决方案。
|
15天前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
28天前
|
缓存 NoSQL 关系型数据库
Redis和Mysql如何保证数据⼀致?
在项目中,为了解决Redis与Mysql的数据一致性问题,我们采用了多种策略:对于低一致性要求的数据,不做特别处理;时效性数据通过设置缓存过期时间来减少不一致风险;高一致性但时效性要求不高的数据,利用MQ异步同步确保最终一致性;而对一致性和时效性都有高要求的数据,则采用分布式事务(如Seata TCC模式)来保障。
58 14
|
1月前
|
SQL 前端开发 关系型数据库
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
54 9
|
2月前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
|
2月前
|
NoSQL 关系型数据库 MySQL
MySQL与Redis协同作战:优化百万数据查询的实战经验
【10月更文挑战第13天】 在处理大规模数据集时,传统的关系型数据库如MySQL可能会遇到性能瓶颈。为了提升数据处理的效率,我们可以结合使用MySQL和Redis,利用两者的优势来优化数据查询。本文将分享一次实战经验,探讨如何通过MySQL与Redis的协同工作来优化百万级数据统计。
70 5
|
1月前
|
SQL 关系型数据库 MySQL
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
47 1
|
1月前
|
SQL 关系型数据库 MySQL
mysql数据误删后的数据回滚
【11月更文挑战第1天】本文介绍了四种恢复误删数据的方法:1. 使用事务回滚,通过 `pymysql` 库在 Python 中实现;2. 使用备份恢复,通过 `mysqldump` 命令备份和恢复数据;3. 使用二进制日志恢复,通过 `mysqlbinlog` 工具恢复特定位置的事件;4. 使用延迟复制从副本恢复,通过停止和重启从库复制来恢复数据。每种方法都有详细的步骤和示例代码。
219 2