MySQL (事务)
1、DCL用来控制数据库的访问,包括如下SQL语句:
- 
GRANT:授予访问权限 
- 
REVOKE:撤销访问权限 
- 
COMMIT:提交事务处理 
- 
ROLLBACK:事务处理回退 
- 
SAVEPOINT:设置保存点 
- 
LOCK:对数据库的特定部分进行锁定 
2、事务的ACID特性
- 
原子性(Atomicity):原子意为最小的粒子,或者说不能再分的事物。数据库事务的不可再分的原则即为原子性。 组成事务的所有SQL必须:要么全部执行,要么全部取消(就像上面的银行例子)。 
- 
一致性(Consistency):指数据的规则,在事务前/后应保持一致 
- 
隔离性(Isolation):简单点说,某个事务的操作对其他事务不可见的. 
- 
持久性(Durability):当事务提交完成后,其影响应该保留下来,不能撤消 
3、事务的用法
- 
- 
执行sql操作(普通sql操作) 
- 
- 
- 
不可重复读: 对于两个事务 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)。 
 
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号