zoukankan      html  css  js  c++  java
  • SQL中有关死锁的一些知识

    所谓死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程成为死锁进程。

    由于资源占用是互斥的,当某个进程提出申请资源后,使得有关进程在无外力协助下,永远分配不到必须的资源而无法继续运行,这就产生了一种特殊现象死锁。

    一种情形,此时执行程序中两个或多个线程发生永久堵塞i(等待),每个线程都在等待被其他线程占用并堵塞了的资源。例如,如果线程A锁住了记录1并等待记录2,而线程B锁住了记录2并等待记录1,这样两个线程就发生了死锁现象。

    产生死锁的必要条件
    1、互斥条件:一个资源每次只能被一个进程使用
    2、请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
    3、不剥夺条件:进程已获得的资源,在未使用完之前,不能强行剥夺。
    4、循环等待条件:若干进程之间形成以一种头尾相连的循环等待资源关系。
    这四个条件是死锁的必要条件,只要系统发生死锁,这些条件必然成立,而只要上述条件之一 不满足,就不会发生死锁。

    死锁的解除和预防
    1、按同一顺序访问对象
    2、避免事物中的用户交互
    3、保持事物简短并在一个批处理中
    4、使用低隔离级别
    5、使用绑定连接


    死锁的建议
    1、对于频繁使用的表使用集簇化的索引
    2、设法避免一次性影响大量记录的T_SQL语句,特别是INSERT和UPDATE语句
    3、设法让UPDATE和DELETE语句使用索引
    4、使用嵌套事务时,避免提交和回退冲突
    5、对一些数据不需要及时读取更新值的表在写SQL的时候在表后台加上(nolock),
    如:select * from tableA(nolock)



    概述
    所谓封锁,就是一个事务可向系统提出请求,对被操作的数据加锁(Lock)。其他事务
    必须等到此事务解锁(Unlock)之后才能访问该数据。从而,在多个用户并发访问数据库时,确保不互相干扰。可锁定的单位是:行、页、表、盘区和数据库。


    锁的类型:
    1、共享(S)锁:用于读操作
    多个事务可封锁一个共享单位的数据。
    任何事务都不能修改加S锁的数据。
    通常是加S锁的数据被读取完毕,S锁立即被释放。
    2、独占(X)锁:用于写操作
    仅允许一个事务封锁此共享数据。
    其他任何事务必须等到X锁被释放才能对该数据进行访问。
    X锁一直到事务结束才能被释放。
    3、更新(U)锁
    用来预订要对此页施加X锁,它允许其他事务读,但不允许再施加U锁或X锁。
    当被读取数据页将要被更新时,则升级为X锁。

  • 相关阅读:
    HTTP/1.1 Status Code Definitions
    宽带到底“宽不宽”
    tmux的简介及使用
    Simple Gesture – Fling
    使用postfix搭建匿名smtp服务器
    dos2unix和unix2dos命令使用 [〓 脚本功略 〓]
    Android Coding: Gestures Builder: create your gestures library
    Android Gesture 手势识别使用实例 Android mobile ITeye论坛
    使用socat进行端口转发
    notepad++在编辑python文件时以4个空格代替TAB
  • 原文地址:https://www.cnblogs.com/ahao214/p/2548410.html
Copyright © 2011-2022 走看看