首页 > 数据库技术 > 详细

MySQL (事务)

时间:2020-10-21 22:25:21      阅读:29      评论:0      收藏:0      [点我收藏+]

1、DCL用来控制数据库的访问,包括如下SQL语句:

  • GRANT:授予访问权限

  • REVOKE:撤销访问权限

  • COMMIT:提交事务处理

  • ROLLBACK:事务处理回退

  • SAVEPOINT:设置保存点

  • LOCK:对数据库的特定部分进行锁定

2、事务的ACID特性

  • 原子性(Atomicity):原子意为最小的粒子,或者说不能再分的事物。数据库事务的不可再分的原则即为原子性。 组成事务的所有SQL必须:要么全部执行,要么全部取消(就像上面的银行例子)。

  • 一致性(Consistency):指数据的规则,在事务前/后应保持一致

  • 隔离性(Isolation):简单点说,某个事务的操作对其他事务不可见的.

  • 持久性(Durability):当事务提交完成后,其影响应该保留下来,不能撤消

3、事务的用法

  • 开启事务(start transaction)

  • 执行sql操作(普通sql操作)

  • 提交/回滚(commit/rollback)

4、 数据库的隔离级别

  • 脏读: 对于两个事务 T1, T2, T1 读取了已经被 T2 更新但还没有被事务提交的字段. 之后, 若 T2 回滚事务, T1读取的内容就是临时且无效的.

  • 不可重复读: 对于两个事务 T1, T2, T1 读取了一个字段, 然后 T2 更新并提交了该字段. 之后, T1再次读取同一个字段, 值就不同了.

  • 幻读: 对于两个事务 T1, T2, T1 从一个表中读取了一个字段, 然后 T2 在该表中插入、删除了一些新的行. 之后, 如果 T1 再次读取同一个表, 就会多出、少了几行.

  • l 查看当前的隔离级别: SELECT @@tx_isolation;

    l 查看全局的隔离级别:select @@global.tx_isolation;

    l 设置当前 mySQL 连接的隔离级别: set tx_isolation =‘repeatable-read‘;

  •  

    设置数据库系统的全局的隔离级别: set global tx_isolation =‘read-committed‘。

5、关联查询、联合查询

  • 关联条件
  • WHERE:适用于所有关联查询

  • ON:只能和JOIN一起使用,只能写关联条件。虽然关联条件可以并到WHERE中和其他条件一起写,但分开写可读性更好。

  • USING:只能和JOIN一起使用,而且要求两个关联字段在关联表中名称一致,而且只能表示关联字段值相等

  • 内连接(INNER JOIN):
    • 有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行                                   
  • 外连接(OUTER JOIN):
    • 左外连接(LEFT OUTER JOIN),简称左连接(LEFT JOIN)
    • 右外连接(RIGHT OUTER JOIN),简称右连接(RIGHT JOIN)

    • 全外连接(FULL OUTER JOIN),简称全连接(FULL JOIN)。

MySQL (事务)

原文:https://www.cnblogs.com/xlwg/p/13854056.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!