MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

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

  DML:数据操作语言

插入数据1

> insert atb (name,age) values (tuchao,21),(tyz,25);

插入数据2

> insert atb set name='jerry',age=19;

插入数据3,可以把查询到的数据,插入表中。

> insert into atb(name) select user from mysql.user;

更新数据

> update atb set age=20 where name='root';

清除数据

> delete from atb where name='root';

wKiom1OqxMrhXwjaAAEy_KJpCog724.jpg

清空重置表,Auto_increment也会重置。

> truncate table tb9;

mysql内置函数

> select last_insert_id();

使用between显示tb9表中,年龄大于20小于40的用户。

> select name,age from tb9 where age between 20 and 40;

> select name,age from tb9 where age>=20 and age<=40;

这两条语句功能一样

wKioL1Oq0u7yN9H2AAGdIeum3ss322.jpg

in表示在规定的集合内

使用in查询age在10,20,30,40,50的用户。

> select name,age from tb9 where age in (10,20,30,40,50);

wKiom1Oq1MzB7tGKAAExwnHkK1w999.jpg

is null;    表示值为空

is not null    表示值不为空

mysql聚合函数:

max()最大值,min()最小值,avg()平均值,count()统计值

wKiom1Oq2zCikkZCAAFyNIPNS94545.jpg

查询每个班有多少位学生,使用group对班级分组。

> select ClassID,count(Name) from students group by ClassID;

wKioL1Ors7mjl_R7AACxUlpu2v4630.jpg

使用where过滤,没有班级的学生将不予显示。

> select ClassID,count(Name) from students where ClassID is not null  group by ClassID;

wKioL1Ors-vhbgiiAADKan2rCT0042.jpg

查找学生人数大于3的班级,这里使用 as 将前面select 定义别名 counts,然后后使用group by 对ClassID做分组,最后使用了having子句做算数表达式过滤。

> select ClassID,count(Name) as counts  from students group by ClassID having counts>=3;

wKiom1OrtdzTnJRcAADDRWD_nPU203.jpg

显示出有多少男生,多少女生。

> select Gender,count(Gender) from students group by Gender;

wKioL1OrtzjC564SAACi8zy03Nk518.jpg

显示男生与女生的平均年龄。

> select Gender,avg(Age) from students group by Gender;

wKiom1OruDnxjEvSAACf_kf48F0838.jpg

依照年龄进行排序(升序)

> select Name,Age from students order by Age;

wKioL1OruQSyP_OMAAGXE_JAYmk853.jpg

依照年龄进行排序(降序)

> select Name,Age from students order by Age desc;

wKioL1OruWWhTOJWAAGj9QIzKAI903.jpg

显示年龄最大的5个。

> select Name,Age from students order by Age desc limit 5;

使用distinct显示有多少种类别。

> select distinct Gender from students;

以性别分组,显示各组年龄中的最大值;

> select Gender,max(Age) from students group by Gender;

wKioL1Oru-PQJEssAACYs8uhEVc108.jpg

以班级分组,显示各组年龄中的最小值;只显示最小年龄小于20的班级,并排序。

> select ClassID,min(Age) from students group by ClassID having min(Age)<20 order by min(Age);

wKiom1OrvfnDoPLbAADOyVliQek862.jpg

以性别分组,显示各组年龄的年龄之和,要求将年龄之和逆序排列;

> select Gender,sum(Age) from students group by Gender order by sum(Age)  desc;

wKioL1Orv2TRUfx3AACrbg2ojS0170.jpg

以年龄分组,显示各组中的人数;

> select Age,count(Name) from students group by Age;

wKiom1OrwMaiKlGPAADZ7vETwS8469.jpg

表联接:

交叉联接;

内联接,让两张表当中对应的两个字段的值建立等值联接关系。

> select * from students,classes where students.ClassID = classes.ClassID;

wKioL1OrxZLA6PzFAAQMmgk83Io517.jpg

多表查询,显示每位学生的年龄,性别,属于哪个门派的。

> select Name,Class,Age,Gender  from students,classes where students.ClassID = classes.ClassID;

wKiom1OryATAlYWyAALJd47USWY677.jpg

外联接,以一张表中的每一行为标准跟另外一张表建立联接关系,如果另外一张表没有与之对应的值,则不显示即可。

    左外联接:

            left_table left join right_table on  conditon

以左表为基准显示

> select Name,Class from students left join classes on students.ClassID = classes.ClassID;

wKioL1Ory_3xTulPAAJN6xKdpHU812.jpg

    右外联接:

              right_table left join table on  conditon

以右边的表为标准,只要右边表中有的字段值全部显示出来,没有就留空,如果两边都没有值都为空,称为全外联接。

> select Name,Class from students right join classes on students.ClassID = classes.ClassID;

wKioL1OrzlvggATMAAJVAaBoTHg555.jpg

使用别名简写:

> select Name,Class,Age,Gender from students as a right join classes as b on a.ClassID = b.ClassID;

多表查询,联接4个表显示,每位学生姓名与对应课程。

> select Name,Course from students,classes,coc,courses where students.ClassID = classes.ClassID and classes.ClassID = coc.ClassID and coc.CourseID = courses.CourseID;

子查询

要求显示学生年龄大于平均年龄的学生姓名。

> select Name from students where Age > (select avg(Age) from students);

wKioL1Or2FugMKXsAAC_x304jWk021.jpg

要求显示选了没有课程号的班级,这里也是使用子查询。

> select ClassID from coc where CourseID not in (Select CourseID from courses);

 要求显示大于全校平均年龄的同学的总数

 > select count(Name) from students where Age > (select avg(Age) from students);

锁机制

读锁    LOCK  TABLES  TABLE_name  READ

写锁    LOCK  TABLES  TABLE_name  WRITE 

释放锁      UNLOCK   TABLES

关闭所有表    FLUSH  TABLES

导出数据库
# mysqldump -u root -p --databases hellodb > hellodb.sql

用sed替换MyISAM为InnoDB引擎。

# sed -i 's/ENGINE=MyISAM/ENGINE=Innodb/g' hellodb.sql

导入数据库

# mysql -uroot -p < hellodb.sql

 控制事务自动提交的变量

> show global variables like 'autocommit' ;

wKioL1OsJ2_wOpR7AACHRTrzbW4447.jpg

启动事务

> start transaction;

手动提交命令

commit

回滚命令

rollback

记录保存点

> savepoint pp1;

回滚至保存点

> rollback to pp1;

RDBMS    事务的隔离级别;

 READ-UNCOMMITTED        读未提交
 READ-COMMITTED              读提交
 REPEATABLE-READ            重读
 SERIALIZABLE                        串行

> show session variables like 'tx_isolation';

wKiom1OsLTDzoGVuAACdK0MehB8882.jpg



本文转自qw87112 51CTO博客,原文链接:http://blog.51cto.com/tchuairen/1430924


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
数据采集 JSON 数据可视化
JSON数据解析实战:从嵌套结构到结构化表格
在信息爆炸的时代,从杂乱数据中提取精准知识图谱是数据侦探的挑战。本文以Google Scholar为例,解析嵌套JSON数据,提取文献信息并转换为结构化表格,通过Graphviz制作技术关系图谱,揭示文献间的隐秘联系。代码涵盖代理IP、请求头设置、JSON解析及可视化,提供完整实战案例。
163 4
JSON数据解析实战:从嵌套结构到结构化表格
|
1月前
|
JSON 监控 网络协议
Bilibili直播信息流:连接方法与数据解析
本文详细介绍了自行实现B站直播WebSocket连接的完整流程。解析了基于WebSocket的应用层协议结构,涵盖认证包构建、心跳机制维护及数据包解析步骤,为开发者定制直播数据监控提供了完整技术方案。
|
1月前
|
前端开发 JavaScript Java
优雅草卓伊凡:全栈工程师并非盲目学语言,转型价值全解析
优雅草卓伊凡:全栈工程师并非盲目学语言,转型价值全解析
49 0
优雅草卓伊凡:全栈工程师并非盲目学语言,转型价值全解析
|
1月前
|
机器学习/深度学习 JSON 算法
淘宝拍立淘按图搜索API接口系列的应用与数据解析
淘宝拍立淘按图搜索API接口是阿里巴巴旗下淘宝平台提供的一项基于图像识别技术的创新服务。以下是对该接口系列的应用与数据解析的详细分析
|
2月前
|
Java API 数据处理
深潜数据海洋:Java文件读写全面解析与实战指南
通过本文的详细解析与实战示例,您可以系统地掌握Java中各种文件读写操作,从基本的读写到高效的NIO操作,再到文件复制、移动和删除。希望这些内容能够帮助您在实际项目中处理文件数据,提高开发效率和代码质量。
60 4
|
1月前
|
缓存 监控 搜索推荐
【实战解析】smallredbook.item_get_video API:小红书视频数据获取与电商应用指南
本文介绍小红书官方API——`smallredbook.item_get_video`的功能与使用方法。该接口可获取笔记视频详情,包括无水印直链、封面图、时长、文本描述、标签及互动数据等,并支持电商场景分析。调用需提供`key`、`secret`和`num_iid`参数,返回字段涵盖视频链接、标题、标签及用户信息等。同时,文章提供了电商实战技巧,如竞品监控与个性化推荐,并列出合规注意事项及替代方案对比。最后解答了常见问题,如笔记ID获取与视频链接时效性等。
|
2月前
|
存储 监控 算法
探秘员工泄密行为防线:基于Go语言的布隆过滤器算法解析
在信息爆炸时代,员工泄密行为对企业构成重大威胁。本文聚焦布隆过滤器(Bloom Filter)这一高效数据结构,结合Go语言实现算法,帮助企业识别和预防泄密风险。通过构建正常操作“指纹库”,实时监测员工操作,快速筛查可疑行为。示例代码展示了如何利用布隆过滤器检测异常操作,并提出优化建议,如调整参数、结合日志分析系统等,全方位筑牢企业信息安全防线,守护核心竞争力。
|
2月前
|
数据采集 前端开发 API
SurfGen爬虫:解析HTML与提取关键数据
SurfGen爬虫:解析HTML与提取关键数据
|
1月前
|
存储 缓存 监控
如何高效爬取天猫商品数据?官方API与非官方接口全解析
本文介绍两种天猫商品数据爬取方案:官方API和非官方接口。官方API合法合规,适合企业长期使用,需申请企业资质;非官方接口适合快速验证需求,但需应对反爬机制。详细内容涵盖开发步骤、Python实现示例、反爬策略、数据解析与存储、注意事项及扩展应用场景。推荐工具链包括Playwright、aiohttp、lxml等。如需进一步帮助,请联系作者。
|
1月前
|
JSON API 数据格式
淘宝商品评论API接口系列的应用与数据解析
在电商平台中,用户评论是了解商品质量、服务水平和用户满意度的重要数据来源。淘宝作为中国最大的电商平台,提供了商品评论API接口,帮助开发者获取和分析用户评价数据。本文将介绍淘宝商品评论API接口系列的作用、使用方法,并通过示例展示如何调用API并解析返回的JSON数据。

推荐镜像

更多
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等