ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

SQL之事务

2019-05-10 21:53:25  阅读:202  来源: 互联网

标签:insert 事务 VALUES human SQL NULL man


●事务的ACID(acid)属性

➢1.原子性(Atomicity )

原子性是指事务是-一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

➢2. 一致性(Consistency)

事务必须使数据库从一一个--致性状态变换到另外一一个--致性状态

➢3.隔离性(Isolation)

事务的隔离性是指一- 个事务的执行不能被其他事务干扰,即一一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。

➢4.持久性(Durability)

持久性是指-一个事务-一旦被提交,它对数据库中数据的改变就是永久性的,接下来的其他操作和数据库故障不应该对其有任何影响

●事务的类型

 隐式事务: 事务没有明显的开启和结束的标记比如insert、update、 delete语句
delete from:    表where id =1;
显式事务: 事务具有明显的开启和结束的标记前提 , 必须先设置自动提交功能为禁用  set autocommit = 0; ●事务的使用
#步骤一:开启事务
set autocommit = 0;
start transaction ; #可选的
#步骤二: 编写事务的sql语句(select , insert , update , delete) 
SELECT * FROM sys;
...
#步骤三:结束事务
commit ;  #提交事务
#rollback; #回滚事务,即使事务执行成功,表中数据也不会保存在磁盘中,但是会将事务中操作的表显示,类似于SELECT出来的表可以显示但是不会保存
●示例 1)成功执行
DROP DATABASE IF EXISTS human;
CREATE DATABASE IF NOT EXISTS human;
USE human;
CREATE TABLE man(
    id INT PRIMARY KEY AUTO_INCREMENT ,
    name VARCHAR(20) NOT NULL
);

SET AUTOCOMMIT = 0;
START TRANSACTION;
insert man
VALUES (NULL,'archer'),(NULL,'saber'),(NULL,'lancer') ;
#insert man
#VALUES (NULL,NULL);
SELECT * FROM man;
COMMIT;
#ROLLBACK; #这里不进行回滚操作,如果需要回滚,那么将COMMIT注释并撤销这句的注释就好

2)失败执行(事务中部分语句无法执行,导致整个事务没有提交)

DROP DATABASE IF EXISTS human;
CREATE DATABASE IF NOT EXISTS human;
USE human;
CREATE TABLE man(
    id INT PRIMARY KEY AUTO_INCREMENT ,
    name VARCHAR(20) NOT NULL
);

SET AUTOCOMMIT = 0;
START TRANSACTION;
insert man
VALUES (NULL,'archer'),(NULL,'saber'),(NULL,'lancer') ;
insert man
VALUES (NULL,NULL);#这条语句无法执行
SELECT * FROM man;
COMMIT;
#ROLLBACK;

 

 

标签:insert,事务,VALUES,human,SQL,NULL,man
来源: https://www.cnblogs.com/winter-bamboo/p/10846881.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有