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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS AI 助手,专业版
RDS Agent(兼容OpenClaw),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


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
8月前
|
SQL 关系型数据库 MySQL
MySQL锁机制:并发控制与事务隔离
本文深入解析了MySQL的锁机制与事务隔离级别,涵盖锁类型、兼容性、死锁处理及性能优化策略,助你掌握高并发场景下的数据库并发控制核心技巧。
|
9月前
|
存储 监控 Oracle
MySQL事务
MySQL事务具有ACID特性,包括原子性、一致性、隔离性和持久性。其默认隔离级别为可重复读,通过MVCC和间隙锁解决幻读问题,确保事务间数据的一致性和并发性。
MySQL事务
|
7月前
|
关系型数据库 MySQL 数据库
【赵渝强老师】MySQL的事务隔离级别
数据库并发访问时易引发数据不一致问题。如客户端读取到未提交的事务数据,可能导致“脏读”。MySQL通过四种事务隔离级别(读未提交、读已提交、可重复读、可序列化)控制并发行为,默认为“可重复读”,以平衡性能与数据一致性。
435 0
|
9月前
|
存储 SQL 关系型数据库
MySQL中binlog、redolog与undolog的不同之处解析
每个都扮演回答回溯与错误修正机构角色: BinLog像历史记载员详细记载每件大大小小事件; RedoLog则像紧急救援队伍遇见突發情況追踪最后活动轨迹尽力补救; UndoLog就类似时间机器可倒带历史让一切归位原始样貌同时兼具平行宇宙观察能让多人同时看见各自期望看见历程而互不干扰.
551 9
|
8月前
|
关系型数据库 MySQL 数据库
MySql事务以及事务的四大特性
事务是数据库操作的基本单元,具有ACID四大特性:原子性、一致性、隔离性、持久性。它确保数据的正确性与完整性。并发事务可能引发脏读、不可重复读、幻读等问题,数据库通过不同隔离级别(如读未提交、读已提交、可重复读、串行化)加以解决。MySQL默认使用可重复读级别。高隔离级别虽能更好处理并发问题,但会降低性能。
287 0
|
10月前
|
存储 SQL 关系型数据库
MySQL 核心知识与索引优化全解析
本文系统梳理了 MySQL 的核心知识与索引优化策略。在基础概念部分,阐述了 char 与 varchar 在存储方式和性能上的差异,以及事务的 ACID 特性、并发事务问题及对应的隔离级别(MySQL 默认 REPEATABLE READ)。 索引基础部分,详解了 InnoDB 默认的 B+tree 索引结构(多路平衡树、叶子节点存数据、双向链表支持区间查询),区分了聚簇索引(数据与索引共存,唯一)和二级索引(数据与索引分离,多个),解释了回表查询的概念及优化方法,并分析了 B+tree 作为索引结构的优势(树高低、效率稳、支持区间查询)。 索引优化部分,列出了索引创建的六大原则
269 2
|
10月前
|
存储 SQL 关系型数据库
MySQL 核心知识与性能优化全解析
我整理的这份内容涵盖了 MySQL 诸多核心知识。包括查询语句的书写与执行顺序,多表查询的连接方式及内、外连接的区别。还讲了 CHAR 和 VARCHAR 的差异,索引的类型、底层结构、聚簇与非聚簇之分,以及回表查询、覆盖索引、左前缀原则和索引失效情形,还有建索引的取舍。对比了 MyISAM 和 InnoDB 存储引擎的不同,提及性能优化的多方面方法,以及超大分页处理、慢查询定位与分析等,最后提到了锁和分库分表可参考相关资料。
213 0
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
结构型模式描述如何将类或对象按某种布局组成更大的结构。它分为类结构型模式和对象结构型模式,前者采用继承机制来组织接口和类,后者釆用组合或聚合来组合对象。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象结构型模式比类结构型模式具有更大的灵活性。 结构型模式分为以下 7 种: • 代理模式 • 适配器模式 • 装饰者模式 • 桥接模式 • 外观模式 • 组合模式 • 享元模式
886 140
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
|
算法 测试技术 C语言
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
1391 29
|
前端开发 数据安全/隐私保护 CDN
二次元聚合短视频解析去水印系统源码
二次元聚合短视频解析去水印系统源码
559 4

热门文章

最新文章

推荐镜像

更多