MySQL 主键与事务

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: MySQL 主键与事务

MySQL 主键与事务



一、MySQL 主键和表字段的注释


1.主键及自增

2.表字段的注释

3.多表查询


二、数据库事务概述


1.数据库事务特性(ACID)

2.事务并发不进行事务隔离

3.MySQL 数据库管理事务

1)别名

2)去重

3)AND 和 OR 运算符

4)SQL LIKE 操作符

5)SQL ORDER BY 子句

6)Limit 子句


一、MySQL 主键和表字段的注释



1.主键及自增


每一张表通常会有一个且只有一个主键,来表示每条数据的唯一性。


  • 特性:值不能重复,不能为空 null


格式:create table test (ID int primary key)


主键 + 自增的写法:


格式:create table test (ID int primary key auto_increment)


image.png


  • 注意:自增只能配合主键来使用(如果单独定义则会报错)


2.表字段的注释


mysql> alter table test modify Name varchar(12) comment '用户名';


image.png


3.多表查询


mysql> create table A(ID int primary key auto_increment,Name varchar(12),Department int);
mysql> create table B(ID int primary key auto_increment,Name varchar(12));
mysql> insert into B(Name) values("财务"),("市场");
mysql> insert into A(Name,Department) values("张三",1),("李四",2),("王五",2);


mysql> select B.Name 部门,A.Name from B,A where B.ID=2 and A.Department=2;


image.png


二、数据库事务概述



数据库:关系型数据库(支持事务);非关系型数据库(不支持)


  • 什么是事务:保证成批操作要么完全执行,要么完全不执行,维护数据的完整性。简单来说就是要么成功要么不成功。


一个事务中包含多条 SQL 语句,而且这些 SQL 语句之间存在一定的关系:


  • 事务可以是 N 条 SQL 语句(N >= 0)
  • 不是所有数据库存储引擎都支持事务,InnoDB 存储引擎支持事务处理。


1.数据库事务特性(ACID)


image.png


image.pngimage.png

2.事务并发不进行事务隔离


  • 脏读: 事务 A 读到未提交事务 B 修改的数据,如果此时事务 B 中途执行失败回滚,那么此时事务 A 读取到的就是脏数据。
  • 不可重复读: 同一个事务中,对同一份数据读取的结果不一致(针对数据)。
  • 幻读: 同一个事务中,同一个查询多次返回的结果不一样(针对表中总行)。


区别:


  • 脏读和不可重复读:脏读是事务读取了还未提交事务的更新数据。不可重复读是同一个事务中,几次读取的数据不同。
  • 不可重复读和幻读:都是在同一个事务中,前者是几次读取数据不同,后者是几次读取数据整体不同。


隔离级别:


image.png


  • MySQL 支持上面 4 种隔离级别,默认为可重复读。
  • 如若想修改隔离级别需: sed -i '/\[mysqld]/a transaction-isolation = SERIALIZABLE' /etc/my.cnf


mysql> show variables like '%tx_is%';
mysql> exit
[root@MySQL ~]# sed -i '/\[mysqld]/a transaction-isolation = SERIALIZABLE' /etc/my.cnf
[root@MySQL ~]# systemctl restart mysqld
[root@MySQL ~]# mysql -uroot -p123123 -e "show variables like '%tx_is%';"


image.png


3.MySQL 数据库管理事务


管理事务的三个命令:


  • BEGIN:开始事务,后面有多条数据库操作语句开始执行。
  • COMMIT:开始提交一个事务,对应前面的 BEGIN 操作,将事务处理的结果保存到数据文件中。
  • ROLLBACK:开始回滚一个事务,在 BEGIN 和 COMMIT 中间,将事务中的全部语句撤销,恢复到 BEGIN 之前的数据状态。
  • set autocommit = 0/1:禁用或开启自动提交,自动提交为退出 MySQL 连接程序时,或执行下一条 DML (数据操纵语言) 语句。


mysql> create table C(ID int);
mysql> insert into C values(1),(2);
mysql> select * from C;
mysql> BEGIN;
mysql> insert into C values(3);
mysql> COMMIT;
mysql> select * from C;


image.png


mysql> show variables like 'autocommit';          #查看是否开启自动提交事务
mysql> BEGIN;
mysql> insert into C values(4)
mysql> select * from C;
mysql> exit
[root@localhost ~]# mysql -uroot -p123123 -e "select * from Coco.C where ID=4"


image.png


  • set autocommit=0:在数据库中修改为临时生效(如若想永久修改需 sed -i '/\[mysqld]/a autocommit=0' /etc/my.cnf 来修改)


mysql> set autocommit=0;
mysql> select * from Coco.C;
mysql> insert into Coco.C values(4);
mysql> select * from Coco.C where ID=4;
[root@localhost ~]# mysql -uroot -p123123 -e "select * from Coco.C where ID=4"


image.png


注意:


  • 使用 BEGIN 或 START TRANSACTION 开启一个事务之后,自动提交将保持禁用状态,直到使用 COMMIT 或 ROLLBACK 结束事务。
  • 之后,自动提交模式会恢复到之前的状态,即如果 BEGIN 前 autocommit = 1,则完成本次事务后 autocommit 还是 1。
  • 如果 BEGIN 前 autocommit = 0,则完成本次事务后 autocommit 还是 0。


1)别名


mysql> select ID as "编号",Name as "姓名",Department as "部门" from A where ID=1;
mysql> select ID "编号",Name "姓名",Department "部门" from A where ID=1;


image.png


2)去重

mysql> select distinct Department from A;


image.png


3)AND 和 OR 运算符


  • AND:逻辑与(条件都要满足);OR:逻辑或(条件只需要满足一个)。


mysql> select * from A where ID >= 3 and Department = 2;
mysql> select * from A where ID >= 3 or Department = 2;


image.png


  • in:如果查询某个字段的值为多个时,可以使用 in 关键字。
  • between and:在某两个数值之间包含 and 两边的数。


mysql> select * from A where ID in(1,3,4);
mysql> select * from A where ID not in(1,3,4);
mysql> select * from A where ID between 1 and 3;


image.png


4)SQL LIKE 操作符


  • -_:代表单个未知字符。
  • - %:代表多个未知字符。
  • 例:A% A 开头,%B B 结尾,%C% 包含 C,_D% 第二个字母是 D,%E__ 倒数第三个字母是 E,%@163.com 163 邮箱。


mysql> select * from A where Name like "%三%";
mysql> select * from A where Name like "%三%" or Name like "%四";


image.png


5)SQL ORDER BY 子句


order by:用于排序,by 后面添加排序规则的字段。


  • asc:升序(默认就是升序)
  • desc:降序。


mysql> select * from A order by ID desc;
mysql> select * from A order by Department,ID desc;


image.png


6)Limit 子句


mysql> select * from C;
mysql> select * from C limit 2;
mysql> select * from C limit 0,2;

image.png

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
3月前
|
SQL 关系型数据库 MySQL
MySQL锁机制:并发控制与事务隔离
本文深入解析了MySQL的锁机制与事务隔离级别,涵盖锁类型、兼容性、死锁处理及性能优化策略,助你掌握高并发场景下的数据库并发控制核心技巧。
|
4月前
|
存储 监控 Oracle
MySQL事务
MySQL事务具有ACID特性,包括原子性、一致性、隔离性和持久性。其默认隔离级别为可重复读,通过MVCC和间隙锁解决幻读问题,确保事务间数据的一致性和并发性。
MySQL事务
|
5月前
|
存储 SQL 关系型数据库
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
|
2月前
|
关系型数据库 MySQL 数据库
【赵渝强老师】MySQL的事务隔离级别
数据库并发访问时易引发数据不一致问题。如客户端读取到未提交的事务数据,可能导致“脏读”。MySQL通过四种事务隔离级别(读未提交、读已提交、可重复读、可序列化)控制并发行为,默认为“可重复读”,以平衡性能与数据一致性。
270 0
|
3月前
|
关系型数据库 MySQL 数据库
MySql事务以及事务的四大特性
事务是数据库操作的基本单元,具有ACID四大特性:原子性、一致性、隔离性、持久性。它确保数据的正确性与完整性。并发事务可能引发脏读、不可重复读、幻读等问题,数据库通过不同隔离级别(如读未提交、读已提交、可重复读、串行化)加以解决。MySQL默认使用可重复读级别。高隔离级别虽能更好处理并发问题,但会降低性能。
168 0
|
5月前
|
安全 关系型数据库 MySQL
mysql事务隔离级别
事务隔离级别用于解决脏读、不可重复读和幻读问题。不同级别在安全与性能间权衡,如SERIALIZABLE最安全但性能差,READ_UNCOMMITTED性能高但易导致数据不一致。了解各级别特性有助于合理选择以平衡并发性与数据一致性需求。
185 1
|
12月前
|
SQL 安全 关系型数据库
【MySQL基础篇】事务(事务操作、事务四大特性、并发事务问题、事务隔离级别)
事务是MySQL中一组不可分割的操作集合,确保所有操作要么全部成功,要么全部失败。本文利用SQL演示并总结了事务操作、事务四大特性、并发事务问题、事务隔离级别。
4941 56
【MySQL基础篇】事务(事务操作、事务四大特性、并发事务问题、事务隔离级别)
|
8月前
|
存储 缓存 关系型数据库
MySQL为什么需要主键
本文介绍了MySQL中主键的重要性及最佳实践。主键用于唯一标识表中的每一行,其值必须唯一且不允许为空。主键有助于简化更新和删除操作,避免影响无关行。推荐使用与业务无关的自增ID作为Innodb表的主键,以优化存储结构、减少碎片并提高性能。此外,文章还提到不更新、不重用主键值以及避免使用可能变更的字段(如邮箱)作为主键的良好习惯。最后强调了紧凑索引结构对查询效率的关键作用。
237 0
MySQL为什么需要主键
|
11月前
|
SQL 关系型数据库 MySQL
MySQL事务日志-Undo Log工作原理分析
事务的持久性是交由Redo Log来保证,原子性则是交由Undo Log来保证。如果事务中的SQL执行到一半出现错误,需要把前面已经执行过的SQL撤销以达到原子性的目的,这个过程也叫做"回滚",所以Undo Log也叫回滚日志。
581 7
MySQL事务日志-Undo Log工作原理分析
|
12月前
|
存储 关系型数据库 MySQL
MySQL主键谁与争锋:MySQL为何钟爱自增主键ID+UUID?
本文深入探讨了在MySQL中使用自增类型主键的优势与局限性。自增主键通过保证数据的有序性和减少索引维护成本,提升了查询和插入性能,简化了数据库管理和维护,并提高了数据一致性。然而,在某些业务场景下,如跨表唯一性需求或分布式系统中,自增主键可能无法满足要求,且存在主键值易预测的安全风险。因此,选择主键类型时需综合考虑业务需求和应用场景。
411 2

推荐镜像

更多