這個(gè)問題要具體分析:
創(chuàng)新互聯(lián)建站是一家專業(yè)提供松山企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、H5高端網(wǎng)站建設(shè)、小程序制作等業(yè)務(wù)。10年已為松山眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。
第一,事務(wù)隔離級(jí)別基本兩種模式,一種是阻塞式(read committed,repeatable read,serializable)
,一種是非阻塞式(read uncommitted,snapshot)。
默認(rèn)是read committed,這種情況一般在更新表的時(shí)候,如果不使用hint 提示,基本是先對(duì)表添加IX鎖,級(jí)別不算高,基本和其他鎖兼容,但是repeatable read,serializable 事務(wù)隔離級(jí)別就會(huì)先對(duì)表添加IX鎖,然后向X鎖轉(zhuǎn)化,而X鎖和大多數(shù)鎖都不兼容,容易發(fā)生表阻塞。
第二種隔離級(jí)別不會(huì)有以上問題,但是又引入了其它的問題。
以上是一種情況。
另外一種就是 鎖升級(jí),一個(gè)鎖是96B內(nèi)存,如果太多,sqlserver就會(huì)升級(jí)為表鎖,一般是5000以上行級(jí)鎖就升級(jí)為一個(gè)表X鎖。
所以適當(dāng)?shù)奈募纸M和表分區(qū) 是有必要的。
其次就是資源互相引用導(dǎo)致事務(wù)長(zhǎng)時(shí)間不能釋放,導(dǎo)致真正的死鎖,不過SQL2005以后,這種情況發(fā)生的概率很低。
留個(gè)問題你自己去想。
兩個(gè)SQL,兩個(gè)連接,同時(shí)執(zhí)行。
update A set A.NAME=xxx where A.id=55
update A set A.NAME=xxx where A.id=56, 如果 56 不存在你說會(huì)發(fā)生什么情況呢?
減少程序中 DML(insert,update,delete) 操作所花費(fèi)的時(shí)間,對(duì)此類操作做好隔離控制,防止阻塞。如果事務(wù)產(chǎn)生異常,確保事務(wù)可以正?;貪L。
通常情況下,數(shù)據(jù)庫(kù)鎖表大多是因?yàn)槌绦蛟O(shè)計(jì)不合理導(dǎo)致的,在寫代碼的時(shí)候,我們要對(duì)業(yè)務(wù)場(chǎng)景充分考慮,盡量做到以下兩點(diǎn):減少程序中 DML(insert,update,delete) 操作所花費(fèi)的時(shí)間,對(duì)此類操作做好隔離控制,防止阻塞。如果事務(wù)產(chǎn)生異常,確保事務(wù)可以正?;貪L。
在數(shù)據(jù)庫(kù)開發(fā)過程中,不得不考慮并發(fā)性的問題,因?yàn)楹苡锌赡墚?dāng)別人正在更新表中記錄時(shí),你又從該表中讀數(shù)據(jù),那你讀出來的數(shù)據(jù)有可能就不是你希望得到的數(shù)據(jù)??梢哉f有些數(shù)據(jù)同時(shí)只能有一個(gè)事物去更新,否則最終顯示給用戶的數(shù)據(jù)不是數(shù)據(jù)庫(kù)中現(xiàn)存的數(shù)據(jù)。鎖表就限制不同的事物在同一時(shí)間內(nèi)不允許同時(shí)操作一張表,實(shí)例很簡(jiǎn)單,可以用select來鎖定整張表,那別人就不可能更新或是讀取表的記錄。
詳細(xì)步驟如下:
1、點(diǎn)擊【新建查詢】按鈕,打開SQL命令編輯框,對(duì)數(shù)據(jù)庫(kù)表的操作以及維護(hù)都可以通過編輯SQL命令實(shí)現(xiàn)。
2、在編輯框內(nèi)編輯創(chuàng)建數(shù)據(jù)庫(kù)表的代碼,確認(rèn)代碼無誤后,單擊【執(zhí)行】按鈕,創(chuàng)建數(shù)據(jù)表。
3、創(chuàng)建數(shù)據(jù)表的源代碼如下:
use test go
if exists(select name from sys.tables where name='Student')
drop table Student go
create table Student
(sname nchar(10) primary key,
sex nchar(2) not null,
bir datetime)
數(shù)據(jù)庫(kù)管理系統(tǒng),database management system,簡(jiǎn)稱dbms,是一種操縱和管理數(shù)據(jù)庫(kù)的大型軟件,用于建立、使用和維護(hù)數(shù)據(jù)庫(kù)。用戶通過dbms訪問數(shù)據(jù)庫(kù)中的數(shù)據(jù),數(shù)據(jù)庫(kù)管理員也通過dbms進(jìn)行數(shù)據(jù)庫(kù)的維護(hù)工作。它可使多個(gè)應(yīng)用程序和用戶用不同的方法在同時(shí)或不同時(shí)刻去建立,修改和詢問數(shù)據(jù)庫(kù)。
提供數(shù)據(jù)定義語(yǔ)言(ddl)。用它書寫的數(shù)據(jù)庫(kù)模式被翻譯為內(nèi)部表示。數(shù)據(jù)庫(kù)的邏輯結(jié)構(gòu)、完整性約束和物理儲(chǔ),存結(jié)構(gòu)保存在內(nèi)部的數(shù)據(jù)字典中。數(shù)據(jù)庫(kù)的各種數(shù)據(jù)操作(如查找、修改、插入和刪除等)和數(shù)據(jù)庫(kù)的維護(hù)管理都是以數(shù)據(jù)庫(kù)模式為依據(jù)的。
查看被鎖表:
select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName
from sys.dm_tran_locks where resource_type='OBJECT'
spid 鎖表進(jìn)程
tableName 被鎖表名