## 事务
* 当一个业务逻辑需要多个sql完成时,如果其中某条sql语句出错,则希望整个操作都退回
* 使用事务可以完成退回的功能,保证业务逻辑的正确性
* 事务四大特性(简称ACID)
* 原子性(Atomicity):事务中的全部操作在数据库中是不可分割的,要么全部完成,要么均不执行
* 一致性(Consistency):几个并行执行的事务,其执行结果必须与按某一顺序串行执行的结果相一致
* 隔离性(Isolation):事务的执行不受其他事务的干扰,事务执行的中间结果对其他事务必须是透明的
* 持久性(Durability):对于任意已提交事务,系统必须保证该事务对数据库的改变不被丢失,即使数据库出现故障
* 要求:表的类型必须是innodb或bdb类型,才可以对此表使用事务
* 查看表的创建语句
~~~
show create table students;
~~~
* 修改表的类型
~~~
alter table '表名' engine=innodb;
~~~
* 事务语句
~~~
开启begin;
提交commit;
回滚rollback;
~~~
## 示例1
* 步骤1:打开两个终端,连接mysql,使用同一个数据库,操作同一张表
~~~
终端1:
select * from students;
------------------------
终端2:
begin;
insert into students(sname) values('张飞');
~~~
* 步骤2
~~~
终端1:
select * from students;
~~~
* 步骤3
~~~
终端2:
commit;
------------------------
终端1:
select * from students;
~~~
## 示例2
* 步骤1:打开两个终端,连接mysql,使用同一个数据库,操作同一张表
~~~
终端1:
select * from students;
------------------------
终端2:
begin;
insert into students(sname) values('张飞');
~~~
* 步骤2
~~~
终端1:
select * from students;
~~~
* 步骤3
~~~
终端2:
rollback;
------------------------
终端1:
select * from students;
~~~
- mysql
- 1.创建库和表
- 1.1.数据库简介
- 1.2.安装管理
- 1.3.数据完整性
- 1.4.命令脚本操作
- 2.查询
- 2.1.条件
- 2.2.聚合
- 2.3.分组
- 2.4.排序
- 2.5.分页
- 3.高级
- 3.1.关系
- 3.2.连接
- 3.3.自关联
- 3.4.子查询
- 3.5.内置函数
- 3.6.视图
- 3.7.事务
- 4.与python交互
- 4.1.交互类型
- 4.2.增改删
- 4.3.查询
- 4.4.封装
- 4.5.用户登录
- Nosql简介
- mongodb
- 1.基本操作
- 1.1.环境安装
- 1.2.数据库操作
- 1.3.集合操作
- 1.4.数据类型
- 1.5.数据操作
- 1.6.数据查询
- 1.6.1.Limit与Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.统计个数
- 1.6.5.消除重复
- 2.高级操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.复制(副本集)
- 2.4.备份和恢复
- 2.5.与python交互
- redis
- 1.基本配置
- 2.数据操作
- 2.1.string
- 2.2.键命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高级
- 4.1.发布订阅
- 4.2.主从配置
- 5.与python交互
- 6.login登陆完善