mysql事务与存储引擎实例分析
一、MySQL事务
1、事务的概念
(1)事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。
(2)事务是一个不可分割的工作逻辑单元,在数据库系统上执行并发操作时,事务是最小的控制单元。
(3)多用户同时操作的数据库系统的场景,如银行、保险公司和证券交易系统等等,适用于事务处理。 (4)事务通过事务的整体性以保证数据的一致性。
2、事务的 ACID 特点
注:ACID,是指在可靠数据库管理系统 (DBMS) 中,事务 (transaction) 应该具有的四个特性:原子性 (Atomicity) 、一致性 (Consistency )、隔离性 (Isolation) 、持久性 (Durability) 。这是可靠数据库所应具备的几个特性。
(1)事务具有原子性,也就是说,事务中的操作要么全部执行,要么全部不执行,不可分割。 a、事务是一个完整的操作,事务的各元素是不可分的。
b、事务中的所有元素必须作为一个整体提交或回滚。
c、如果事务中的任何元素失败,则整个事务将失败。
(2)一致性:指在事务开始之前和事务结束以后,数据库的完整性约束没有被破坏。
a、当事务完成时,数据必须处于一致状态。
b、在事务开始前,数据库中存储的数据处于一致状态。
c、在正在进行的事务中,数据可能处于不一致的状态。
d、当事务成功完成时,数据必须再次回到已知的一致状态。
(3)隔离性:当多个事务同时操作相同的数据时,在并发环境中,每个事务都能够使用它自己独立的完整数据区域。 对数据进行修改的所有并发事务是彼此隔离的,表明事务必须是独立的,它不应以任何方式依赖于或影响其他事务。 修改数据的事务可在另一个使用相同数据的事务开始之前访问这些数据,或者在另一-个使用相同数据的事务结束之后访问这些数据。
(4)持久性:在事务完成以后,该事务对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。
a、指不管系统是否发生故障,事务处理的结果都是永久的。
b、一旦事务被提交,事务的效果会被永久地保留在数据库中。
总结:在事务管理中,原子性是基础,隔离性是手段,一致性是目的,持久性是结果。
3、事物之间的互相影响
(1)、脏读:一个事务读取了另一个事务未提交的数据,而这个数据是有可能回滚的。
在一个事务中连续执行两个相同的查询,却得到了不同的结果,这种情况被称为不可重复读。这是由于查询时系统中其他事务修改的提交而引起的。
重新叙述:幻读是指当一个事务修改了一个表中的某些数据行,但是另一个事务同时插入了几行新数据,导致第一个事务查询时发现多了几行数据。同时有另一个事务对该表进行了修改,并插入了一行新数据。操作前一个事务的用户会惊奇地发现表中仍有未修改的数据行,就像出现了幻觉一样。
(4)、丢失更新:两个事务同时读取同一条记录,A先修改记录,B也修改记录 (B不知道A修改过),B提交数据后B的修改结果覆盖了A的修改结果。
二、Mysql及事务隔离级别
(1) 、read uncommitted:读取尚未提交的数据,不解决脏读
(2)、 read committed:读取己经提交的数据,可以解决脏读
(3)、 repeatable read:重读读取,可以解决脏读和不可重复读-------------mysql默认
(4)、 serializable:串行化,可以解决脏读不可重复读和虚读----------------相当于锁表 注:mysql 默认的事务处理级别是 repeatable read,而 Oracle 和 SQL Server 是 read committed
1、查询全局事务隔离级别
show global variables like '%isolation%'; 或 select @@global.tx_isolation;
2、查询会话事务隔离级别
show session variables like '%isolation%'; SELECT @@session.tx_isolation; SELECT @@tx_isolation;
3、设置全局事务隔离级别
set global transaction isolation level read committed; show global variables like '%isolation%';
4、设置会话事务隔离级别
set session transaction isolation level read committed; show session variables like '%isolation%';
三、事务控制语句
1、相关语句
begin; 开启事务
commit; 提交事务,使已对数据库进行的所有修改变为永久性的
rollback; 回滚事务,撤销正在进行的所有未提交的修改
savepoint s1; 建立回滚点,s1为回滚点名称,一个事务中可以有多个
rollback to s1; 回滚到s1回滚点
2、案例
①、创建表
create database school; use school; create table Fmoney( id int(10) primary key not null, name varchar(20), money decimal(5,2)); insert into Fmoney values ('1','srs1','100'); insert into Fmoney values ('2','srs2','200'); select * from Fmoney;
②、测试提交事务
begin; update Fmoney set money= money - 100 where name='srs2'; commit; quit mysql -u root -p use school; select * from Fmoney;
③、测试回滚事务
begin; update Fmoney set money= money + 100 where name='srs2'; select * from Fmoney; rollback; select * from Fmoney;
④、测试多点回滚
begin; update Fmoney set money= money + 100 where name='srs2'; select * from Fmoney; savepoint a; update Fmoney set money= money + 100 where name='srs1'; select * from Fmoney; savepoint b; insert into Fmoney values ('3','srs3','300'); select * from Fmoney; rollback to b; select * from Fmoney;
3、使用 set 设置控制事务
SET AUTOCOMMIT=0; #禁止自动提交 SET AUTOCOMMIT=1; #开启自动提交,Mysql默认为1 SHOW VARIABLES LIKE 'AUTOCOMMIT'; #查看Mysql中的AUTOCOMMIT值
如果没有开启自动提交,当前会话连接的mysql的所有操作都会当成一个事务直到你输入rollback|commit;当前事务才算结束。当前事务结束前新的mysql连接时无法读取到任何当前会话的操作结果。
如果开起了自动提交,mysql会把每个sql语句当成一个事务,然后自动的commit。
当然无论开启与否,begin; commit|rollback; 都是独立的事务。
四、MySQL 存储引擎
1、存储引擎概念介绍
(1)MySQL中的数据用各种不同的技术存储在文件中,每一种技术都使用不同的存储机制、索引技巧、锁定水平,并最终提供不同的功能和能力,这些不同的技术以及配套的功能在MySQL中称为存储引擎。
(2)存储引擎是MySQL将数据存储在文件系统中的存储方式或者存储格式
(3)MySQL 常用的存储引擎有: a、MylSAM b、InnoDB
(4)MySQL数据库中的组件,负责执行实际的数据I/O操作
(5)MySQL系统中,存储引擎处于文件系统之.上,在数据保存到数据文件之前会传输到存储引擎,之后按照各个存储引擎的存储格式进行存储。
2、查看系统支持的存储引擎
show engines;
3、查看表使用的存储引擎
(1)方法一:直接查看 show table status from 库名 where name='表名'\G; 例: show table status from school where name='class'\G; (2)方法二:进入数据库查看 use 库名; show create table 表名\G; 例: use school; show create table class\G;
4、修改存储引擎
(1) 方法一:通过 alter table 修改 use 库名; alter table 表名 engine=MyISAM; 例: use school; alter table class engine=MYISAM; (2)方法二:通过修改 /etc/my.cnf 配置文件,指定默认存储引擎并重启服务 注意:此方法只对修改了配置文件并重启mysql服务后新创建的表有效,已经存在的表不会有变更。 vim /etc/my.cnf ...... [mysqld] ...... default-storage-engine=INNODB systemctl restart mysql.service (3)方法三:通过 create table 创建表时指定存储引擎 use 库名; create table 表名(字段1 数据类型,...) engine=MyISAM; 例: mysql -u root -p use school; create table test7(id int(10) not null,name varchar(20) not null) engine=MyISAM;
以上是mysql事务与存储引擎实例分析的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undress AI Tool
免费脱衣服图片

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

要显示MySQL中的所有数据库,需使用SHOWDATABASES命令;1.登录MySQL服务器后执行SHOWDATABASES;命令即可列出当前用户有权访问的所有数据库;2.系统数据库如information_schema、mysql、performance_schema和sys默认存在,但权限不足的用户可能无法看到;3.也可通过SELECTSCHEMA_NAMEFROMinformation_schema.SCHEMATA;查询并筛选数据库,例如排除系统数据库以仅显示用户创建的数据库;确保使用

要为现有表添加主键,需使用ALTERTABLE语句配合ADDPRIMARYKEY子句。1.确保目标列无NULL值、无重复且定义为NOTNULL;2.单列主键语法为ALTERTABLE表名ADDPRIMARYKEY(列名);3.多列组合主键语法为ALTERTABLE表名ADDPRIMARYKEY(列1,列2);4.若列允许NULL,需先执行MODIFY设置为NOTNULL;5.每张表仅能有一个主键,添加前需删除旧主键;6.如需自增,可使用MODIFY设置AUTO_INCREMENT。操作前确保数据

检查MySQL服务是否运行,使用sudosystemctlstatusmysql确认并启动;2.确保bind-address设置为0.0.0.0以允许远程连接,并重启服务;3.验证3306端口是否开放,通过netstat检查并配置防火墙规则允许该端口;4.对于“Accessdenied”错误,需核对用户名、密码和主机名,登录MySQL后查询mysql.user表确认权限,必要时创建或更新用户并授权,如使用'your_user'@'%';5.若因caching_sha2_password导致认证失

使用mysqldump是备份MySQL数据库最常用且有效的方法,它能生成包含表结构和数据的SQL脚本。1.基本语法为:mysqldump-u[用户名]-p[数据库名]>backup_file.sql,执行后输入密码即可生成备份文件。2.备份多个数据库使用--databases选项:mysqldump-uroot-p--databasesdb1db2>multiple_dbs_backup.sql。3.备份所有数据库使用--all-databases:mysqldump-uroot-p

B-TreeindexesarebestformostPHPapplications,astheysupportequalityandrangequeries,sorting,andareidealforcolumnsusedinWHERE,JOIN,orORDERBYclauses;2.Full-Textindexesshouldbeusedfornaturallanguageorbooleansearchesontextfieldslikearticlesorproductdescripti

UNIONremovesduplicateswhileUNIONALLkeepsallrowsincludingduplicates;1.UNIONperformsdeduplicationbysortingandcomparingrows,returningonlyuniqueresults,whichmakesitsloweronlargedatasets;2.UNIONALLincludeseveryrowfromeachquerywithoutcheckingforduplicates,

可以通过在GROUP_CONCAT()函数中使用SEPARATOR关键字来自定义分隔符;1.使用SEPARATOR指定自定义分隔符,如SEPARATOR';'可将分隔符改为分号加空格;2.常见示例包括使用管道符'|'、空格''、换行符'\n'或自定义字符串'->'作为分隔符;3.注意分隔符必须为字符串字面量或表达式,且结果长度受group_concat_max_len变量限制,可通过SETSESSIONgroup_concat_max_len=10000;调整;4.SEPARATOR为可选

使用LOCKTABLES可手动锁定表,READ锁允许多会话读但不可写,WRITE锁为当前会话提供独占读写权限且其他会话无法读写;2.锁定仅限当前连接,执行STARTTRANSACTION等命令会隐式释放锁,锁定后只能访问被锁表;3.仅在MyISAM表维护、数据备份等特定场景使用,InnoDB应优先使用事务和行级锁如SELECT...FORUPDATE以避免性能问题;4.操作完成后必须执行UNLOCKTABLES显式释放锁,否则可能导致资源阻塞。
