MySQL | 数据库的管理和操作【表的增删改查】(二)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL | 数据库的管理和操作【表的增删改查】(二)

MySQL | 数据库的管理和操作【表的增删改查】(一):https://developer.aliyun.com/article/1425881

二、查询(Retrieve)

全列查找

全列查找(查找整个表的所有行,所有列)

select * from 表名
  • 这里面的*表示所有的列,这种特殊含义的符号,计算机中叫做【通配符】

但是这里执行select *操作,肯会非常危险

如果数据量就几百几千,就没有什么事,如果数据量有几亿,几十亿select *操作就很麻烦了,这个操作会瞬间吃满硬盘带宽和网络带宽,就可能导致其他程序无法使用硬盘或者使用网络

那么怎么办呢?有办法吗?有的!


当你需要操作的时候,一定要拉上一个人和你一起操作O(∩_∩)O哈哈~

指定列查询

-- 指定列的顺序不需要按定义表的顺序来 
select 列名,列名...from 表名;
  • 我们需要哪些列就查询哪些列
select name,gender from student;

表达式查询

  • 查询过程中,可以做一些简单的运算~~
  • 这个是进行之间的运算
create table exam_result (id int,name varchar(20),chinese decimal(3,1),math decimal(3,1),english decimal(3,1));

insert into exam_result (id,name,chinese,math,english) values 
  (1,'唐三藏', 67, 98, 56), 
  (2,'孙悟空', 87.5, 78, 77), 
  (3,'猪悟能', 88, 98.5, 90), 
  (4,'曹 孟德', 82, 84, 67), 
  (5,'刘玄德', 55.5, 85, 45), 
  (6,'孙权', 70, 73, 78.5), 
  (7,'宋公明', 75, 65, 30);

  • 接下来就看看查询字段为表达式
  • 可以在查询的时候,针对分数进行变换;比如让查询的math成绩都在原来的基础上 + 10分;
select name,math + 10 from exam_result;

  • 这个结果都是在原有的分数上 + 10的
  • 上述这样的查询,数据库服务器硬盘的数据,是否发生了改变?
  • 如果我们再次查询math,此时的结果是 + 10之前的还是 + 10之后的呢

我们再次操作一下~~

小结一下:

我们要要牢记一句话,mysql是一个“客户端-服务器”结构的程序!!!

用户在客户端输入的sql,通过请求发送给服务器,服务器解析并执行sql,把查询的结果从硬盘读取出来,通过网络响应还给客户端,客户端把这些数据以临时表的形式展现出来

这只是在客户端这里显示一下临时表,和服务器那边的硬盘上的表没啥关系

我们还可以查看总成绩,那么怎么查看呢?接着往下看~~

select name,math + chinese + english from exam_result;
  • 表达式查询是让列和列之间进行运算而不是行和行之间

后面还会学一个聚合查询,是行和行之间的运算~~


这就引出了一个查询的时候指定别名~~

指定别名查询

  • 指定别名,就相当于是 起了个“小名”更方便的来理解含义
  • 我们可以使用as关键字来查询
  • 下面进行演示:
select name,math + chinese + english as total from exam_result;
  • 可以看到,我们查询出来的名字发生了变化~~

  • 其中 as可以省略,但是不建议~~

去重

  • 我们可以使用distinct关键字进指定列进行去重,把重复的行只保留一个
  • 接着看~~
select distinct math from exam_result;

  • distinct指定多个列的时候,要求这些列的值都相同,才视为重复

查询结果排序

  • 使用了order by子句,指定某些列进行排序~~,排序可能是升序,也可能是降序
  • order by 是可以根据多个列进行排序~~
  • 比如说按照数学成绩进行升序排序
select name,math from exam_result order by math;

  • 对于MySQL来说,如果一个sql没有指定order by此时查询的结果的顺序,是不可预期的
  • 代码逻辑中,不能依赖这里的查询顺序的
  • 刚刚是升序排序的,那么怎么降序排序呢?只需要在后面加上desc就可以了
select * from exam_result order by math desc;

  • 此处的descdescend单词的缩写,不是describe
  • 还可以使用asc表示升序排序,但是省略不写默认就是升序
  • 还可以指定多个列来排序,多个列之间使用来分割 ,这个列越靠前,就是越关键的排序依据~~
  • 先按照第一列排序,如果第一列的值相同了,再按照第二列排序
select * from exam_result order by math desc,chinese desc;

条件查询

在查询的时候指定筛选条件

  • 需要先描述条件,怎么描述条件呢?
  • sql通过一系列的运算符来表示条件~~
  • 比较运算符:

逻辑运算符:

  • 通过where子句,再搭配上条件表达式,就可以完成条件查询~~
select * from exam_result where english < 60;
  • 我们来看一下

  • 其中的where english < 60相当于针对数据库的表进行遍历,取出每一行数据,把数据代入条件中,看条件是否符合
  • 如果是,这个记录就保留,作为结果集的一部分
  • 如果是 假,这个记录就pass,下一条继续~~

  • 条件查询,可以直接拿两个列进行比较~~
select * from exam_result where chinese > english;

  • 这里和上面的where english < 60一样,都是取出每一行数据,把数据代入条件中,看条件是否符合

  • 条件查询,可以使用表达式来作为条件
select * from exam_result where chinese + english + math < 200;

  • 这样写是不是不明显,那我们还可以下面这样写
select name,chinese+math+english from exam_result where chinese + english + math < 200;

  • 这样写是不是更加直观~~
  • 还记得吗?有一个as的关键词~~
  • 那么是不是可以下面这样写?
select name,chinese + math + english as total from exam_result where total < 200;

  • 可以看到是报错了~~
  • 在上面的代码中,写下一个sql,不是从前往后的执行,执行顺序是有特定的规则的
    执行规则:
  1. 遍历每一行
  2. 把这一行代入where的条件中
  3. 符合条件的结果,再根据select这里指定的列,再进行查询/计算

注意:

此处的total别名不能作为where条件,和当前sql的执行顺序有关,当然,这也是mysql对于语法规定的一部分~~

  • 所以只能写成原有的表达式~
select name,chinese + math + english as total from exam_result where chinese + math + english < 200;

select * from exam_result where chinese > 80 and english > 80;


select * from exam_result where chinese > 80 or english > 80;

  • 如果一个where中既存在and有存在or,那么它们的优先级是先执行and后执行or

范围查询

BETWEEN … AND …

  • 约定的一个前闭后闭区间(包含两侧边界)

select * from exam_result where chinese >= 80 and chinese <= 90;

  • 或者也可以写成下面的代码,这两种写法本质上是一样的~~
select * from exam_result where chinese between 80 and 90;

select * from exam_result where math = 58 or math = 59 or math = 98 or math = 99;

  • 或者也可以这样写:
select * from exam_result where math in(58,59,98,99);

模糊查询

like
  • 模糊匹配,不要求元素完全相同,只要满足一定的规则就可以了
  • like 功能比正则表达式简单的多,

只支持两个用法:

  1. 使用%代表任意0个字符或者N个字符
  2. 使用_代表任意1个字符
  • 列如:
  • 查询姓孙的同学
select * from exam_result where name like '孙%';

  • 可以看到查询出来了,列如用_来模糊查找:

  • 还可以下面这样写~~
  • like '%孙'查询结尾的
  • like'%孙%'查询包含孙的
  • mysql效率比较低的,很容易称为性能瓶颈,模糊匹配更是比较低效的写法,如果这里支持的功能更复杂,反而更拖慢数据库的效率~~
  • 使用数据库,就算优化出来,也达不到要求,我们的做法是不用数据库,数据都放在内存中搜索~~

NULL 的查询

我们要想查询为空(null)的值,那么怎么查询吗?是下面这样吗?

select * from exam_result where chinese = null;

为什么会出现这样的情况?

  • null和其他数值进行运算,结果还是null;
  • null结果在条件中,想当于false
  • 所以null = null 结果等于null --> false;针对这样的问题怎么解决呢?
  • 在sql里提供了这样的一个比较相等的<=>,使用这个比较相等运算,就可以处理null的比较~
  • 可以看到就可以查询成功了
select * from exam_result where chinese <=> null

  • 或者也可以下面这样写,对空值进行判定~~
select * from exam_result where chinese is null;

分页查询

这里所用到的关键字是limit

select * from exam_result limit 3;
  • 可以看到后面这里加上3,就是只显示3条

  • limit还可以搭配offset,声明从那一条开始查询(从0开始计数)
  • 下面进行代码演示~~
select * from exam_result limit 3 offset 3;

  • 还有一种写法:limit 3 offset 6等价于 limit 6,3
  • 这种写法不太推荐,很容易混淆~~
  • limit 这个东西是可以和前面的那些查询搭配使用的~~

列如:查询总分前三名的同学的信息:

  1. 计算每个同学的总成绩(表达式)
  2. 按照成绩排序(降序)
  3. 取前三条记录

代码操作:

select name,chinese + english + math as total from exam_result order by total desc limit 3;
  • 注意这里的order by是可以使用别名的

查询基础部分暂时告一段落~~

MySQL | 数据库的管理和操作【表的增删改查】(三):https://developer.aliyun.com/article/1426560

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
3月前
|
SQL 关系型数据库 MySQL
Go语言数据库编程:使用 `database/sql` 与 MySQL/PostgreSQL
Go语言通过`database/sql`标准库提供统一数据库操作接口,支持MySQL、PostgreSQL等多种数据库。本文介绍了驱动安装、连接数据库、基本增删改查操作、预处理语句、事务处理及错误管理等内容,涵盖实际开发中常用的技巧与注意事项,适合快速掌握Go语言数据库编程基础。
218 62
|
2月前
|
SQL 存储 关系型数据库
MySQL功能模块探秘:数据库世界的奇妙之旅
]带你轻松愉快地探索MySQL 8.4.5的核心功能模块,从SQL引擎到存储引擎,从复制机制到插件系统,让你在欢声笑语中掌握数据库的精髓!
|
2月前
|
SQL Oracle 关系型数据库
比较MySQL和Oracle数据库系统,特别是在进行分页查询的方法上的不同
两者的性能差异将取决于数据量大小、索引优化、查询设计以及具体版本的数据库服务器。考虑硬件资源、数据库设计和具体需求对于实现优化的分页查询至关重要。开发者和数据库管理员需要根据自身使用的具体数据库系统版本和环境,选择最合适的分页机制,并进行必要的性能调优来满足应用需求。
86 11
|
2月前
|
SQL 关系型数据库 MySQL
【赵渝强老师】MySQL中的数据库对象
本教程详细介绍了MySQL数据库中的常见对象,包括表、索引、视图、事件、存储过程和存储函数的创建与管理。内容涵盖表的基本操作、索引的使用、视图简化查询、事件调度功能等,并通过具体示例演示相关SQL语句的使用方法。
|
3月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
592 1
|
4月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
6月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
4月前
|
存储 关系型数据库 MySQL
大数据新视界 --面向数据分析师的大数据大厂之 MySQL 基础秘籍:轻松创建数据库与表,踏入大数据殿堂
本文详细介绍了在 MySQL 中创建数据库和表的方法。包括安装 MySQL、用命令行和图形化工具创建数据库、选择数据库、创建表(含数据类型介绍与选择建议、案例分析、最佳实践与注意事项)以及查看数据库和表的内容。文章专业、严谨且具可操作性,对数据管理有实际帮助。
大数据新视界 --面向数据分析师的大数据大厂之 MySQL 基础秘籍:轻松创建数据库与表,踏入大数据殿堂
|
6月前
|
关系型数据库 MySQL 数据库连接
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
861 82
|
4月前
|
SQL 关系型数据库 MySQL
MySQL下载安装全攻略!小白也能轻松上手,从此数据库不再难搞!
这是一份详细的MySQL安装与配置教程,适合初学者快速上手。内容涵盖从下载到安装的每一步操作,包括选择版本、设置路径、配置端口及密码等。同时提供基础操作指南,如数据库管理、数据表增删改查、用户权限设置等。还介绍了备份恢复、图形化工具使用和性能优化技巧,帮助用户全面掌握MySQL的使用方法。附带常见问题解决方法,保姆级教学让你无忧入门!
MySQL下载安装全攻略!小白也能轻松上手,从此数据库不再难搞!

热门文章

最新文章

推荐镜像

更多