一、數(shù)據(jù)庫(kù)可重復(fù)讀這種隔離級(jí)別的意義
數(shù)據(jù)庫(kù)可重復(fù)讀這種隔離級(jí)別的意義是,repeatable read隔離級(jí)別確保在同一個(gè)事務(wù)中讀取同一行多次,得到的數(shù)據(jù)是穩(wěn)定的,不會(huì)變化,即使這行被并發(fā)執(zhí)行的事務(wù)修改了。這樣的保障是很多應(yīng)用依賴的。
這也和業(yè)務(wù)場(chǎng)景有關(guān)。
比如財(cái)務(wù)對(duì)賬,某個(gè)時(shí)刻內(nèi),我讀取賬目來(lái)對(duì)賬之類(lèi)的操作,這個(gè)時(shí)候肯定不希望讀到的數(shù)據(jù)再發(fā)生變化,比如讀已提交。這樣既保證當(dāng)前業(yè)務(wù)繼續(xù)進(jìn)行,又可以保證我在某一時(shí)刻內(nèi)的操作不會(huì)有影響。相比較串行化的讀寫(xiě)互斥的情況,性能和業(yè)務(wù)處理靈活性上要好一些。否則一旦查詢,其他操作無(wú)法進(jìn)行,一般生產(chǎn)環(huán)境是不允許的。
延伸閱讀:
二、SQL TRUNCATE TABLE清空表語(yǔ)句
SQL TRUNCATE TABLE 語(yǔ)句用來(lái)刪除表中的所有記錄,也即清空表,它類(lèi)似于不帶 WHERE 子句的 DELETE FROM 語(yǔ)句。
TRUNCATE TABLE 和?DROP TABLE
DROP TABLE 用來(lái)刪除表,包括刪除該表的數(shù)據(jù)、結(jié)構(gòu)、索引、觸發(fā)器、約束等所有信息。一旦使用?DROP TABLE 刪除了表,則該表的所有信息都將丟失,該表再也無(wú)法使用了。如果您希望存儲(chǔ)一些數(shù)據(jù),就只能重新創(chuàng)建該表。
TRUNCATE TABLE 僅僅刪除表的所有記錄,表的結(jié)構(gòu)、索引、觸發(fā)器、約束等將被保留,后續(xù)仍然可以使用該表。
TRUNCATE TABLE 和 DELETE FROM
不帶 WHERE 子句的?DELETE FROM 語(yǔ)句同樣可以達(dá)到清空表的效果,但是?TRUNCATE TABLE 使用的系統(tǒng)資源和日志資源更少,因此比?DELETE FROM 更加快速。
DELETE FROM 語(yǔ)句每刪除一行,都會(huì)在事務(wù)日志中為所刪除的行記錄一項(xiàng)。TRUNCATE TABLE 通過(guò)釋放表中數(shù)據(jù)所用的數(shù)據(jù)頁(yè)來(lái)刪除數(shù)據(jù),只會(huì)在事務(wù)日志中記錄頁(yè)的釋放。
此外,TRUNCATE TABLE 還能重置具有自動(dòng)遞增(AUTO_INCREMENT)屬性的字段,而 DELETE FROM 卻不具備該功能。
總結(jié)
當(dāng)您不再需要該表時(shí),使用 DROP TABLE;當(dāng)您仍要保留該表,只是想刪除所有記錄時(shí),使用 TRUNCATE TABLE;當(dāng)你要?jiǎng)h除部分記錄時(shí),使用帶有 WHERE 子句的 DELETE FROM。