MySQL---数据库从入门走向大神系列(一)-基础入门(3)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL---数据库从入门走向大神系列(一)-基础入门

显示出stud表中所有age的平均值:

<span style="font-size:14px;">select avg(age) as averageAge from stud;</span>

image.png



显示所有age平均值的四舍五入。

<span style="font-size:14px;">select round(avg(age)) as averageAge2 from stud;</span>

image.png

还有:

Sum求和。
Max求最大值,
Min求最小值。

<span style="font-size:14px;">select  sum(age)  as sunAge from stud;

select max(age) as maxAge from stud;

select min(age) as minAge from stud;</span>

image.png


选择年龄最小的那个人的名字和年龄:

<span style="font-size:14px;">select sname , age from stud where age = ( selectt min(age) from stud );</span>

这样用in也可以:

<span style="font-size:14px;">select sname ,age from stud where age in(select min(age) from stud);</span>

image.png


再创建一个年龄等于10的行:

<span style="font-size:14px;">insert into stud value('1009','李白',10,'湖南');</span>

再查年龄最小的那个人的年龄:

<span style="font-size:14px;">select age from stud where age=(select min(age) from stud);</span>

image.png


我们可以看到,因为有2个数据的年龄都是最小值,所有显示了2行,但是它们是重复的,完全没必要显示2行。

这个时候我们就要用到:distinct ,把完全相同的行,合并显示!


<span style="font-size:14px;">select distinct age from stud where age = (select min(age) from stud);</span>

image.png



排序-升序和降序:

按年龄升序排:

<span style="font-size:14px;">select * from stud order by age asc;</span>

image.png


按年龄降序排:

<span style="font-size:14px;">select sno,sname,age from stud order by age desc;</span>

image.png



exists存在判断

<span style="font-size:14px;">select sname,age from stud where exists (select * from stud where age = 20);</span>

exists (select * from stud where age=20) ---只要存在age=20的,就返回true、

也就是exists(...) 是判断括号内的表达式是不是null的,如果是null则返回false,否则返回true;

此句因为stud存在age=20的行,所以会输出所有的sname,age。

image.png



分组  group by

<span style="font-size:14px;">select saddress , avg(age) as 平均年龄 from stud group by saddress;</span>

按照saddress来分组,求出每组的平均年龄。

只要saddress不同就是不同的组!


image.png


按照saddress分组后每组的年龄总和:

select saddress,sum(age) as 年龄总和 from stud group by saddress;

image.png


有2个固定搭配:

排序:

select ... from ... where ... order by ...  

分组:

select ... from ... group by ... by ... having ... (条件判断在having后面,不是用where)

image.png

这里的sum(age)也可以用as 别名  取一个别用,在判断的时候直接可以用别名的。



字符串处理函数

<pre name="code" class="sql"><span style="font-size:14px;">Length(str) - 求字符串长度

Ltrim(str) - 去掉左边的空格

Rtrim(str) - 去掉右边的空格

trim(str)  - 去掉两边的空格

Left(str,n); - 从左边取出n个字符

Right(str,n); - 从右边取出n个字符

Substring(str,begin,end) -返回子串

Reverse(str) –返回颠倒的字符串

Lower(str) - 转成小写

Upper(str) - 转成大写

Concat(Str,str…..)串联字符串。

Instr(str,s) – 返回s在str中出面的位置,没有则返回0</span>


这里就只选取几个来演示了:

演示left();

显示saddress开始2个字符为湖南的行

<span style="font-size:14px;">select * from stud where left(saddress,2)='湖南';</span>

image.png



串联字符串:

<span style="font-size:14px;">select concat(snon,sname,saddress) as 串联字符串 from stud;</span>

image.png


instr(str,s) 返回s在str中出面的位置,没有则返回0

其实就是返回字串自一次出现的位置(从1开始计数)

select sname,instr(sname,'三') as ind from stud;'

image.png


本篇博客适于初学SQL的朋友学习,如果想继续学习,请关注我,我会在后续继续加深SQL~

因博主也是刚刚开始学习SQL语句,让我们一起进步吧~

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
26天前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
65 13
|
18天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
32 1
|
20天前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
35 4
|
20天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
35 4
|
15天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
123 0
|
SQL Java 数据库连接
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
192 0
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
|
SQL 关系型数据库 MySQL
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
142 0
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
|
存储 SQL 关系型数据库
MySQL---数据库从入门走向大神系列(五)-存储过程
MySQL---数据库从入门走向大神系列(五)-存储过程
142 0
MySQL---数据库从入门走向大神系列(五)-存储过程
|
数据库
MySQL---数据库从入门走向大神系列(四)-子查询、表与表之间的关系(3)
MySQL---数据库从入门走向大神系列(四)-子查询、表与表之间的关系
203 0
MySQL---数据库从入门走向大神系列(四)-子查询、表与表之间的关系(3)
|
SQL 关系型数据库 MySQL
MySQL---数据库从入门走向大神系列(二)-用Java对MySQL进行增删改查
MySQL---数据库从入门走向大神系列(二)-用Java对MySQL进行增删改查
211 0
MySQL---数据库从入门走向大神系列(二)-用Java对MySQL进行增删改查