采用手動(dòng)增長型字段選取sql server主鍵
sql server主鍵有多種選取的方式,下面為您詳解采用手動(dòng)增長型字段選取sql server主鍵的方式,供您參考,希望對您有所啟迪。
既然自動(dòng)增長型字段會(huì)帶來如此的麻煩,我們不妨考慮使用手動(dòng)增長型的字段,也就是說sql server主鍵的值需要自己維護(hù),通常情況下需要建立一張單獨(dú)的表存儲(chǔ)當(dāng)前sql server主鍵鍵值。還用上面的例子來說,這次我們新建一張表叫IntKey,包含兩個(gè)字段,KeyName以及KeyValue。就像一個(gè)HashTable,給一個(gè) KeyName,就可以知道目前的KeyValue是什么,然后手工實(shí)現(xiàn)鍵值數(shù)據(jù)遞增。在SQL Server中可以編寫這樣一個(gè)存儲(chǔ)過程,讓取鍵值的過程自動(dòng)進(jìn)行。代碼如下:
- CREATE PROCEDURE [GetKey]@KeyName char(10),
- @KeyValue int OUTPUT
- AS
- UPDATE IntKey SET @KeyValueKeyValue = KeyValue =
- KeyValue + 1 WHERE KeyName = @KeyName
- GO
這樣,通過調(diào)用存儲(chǔ)過程,我們可以獲得最新鍵值,確保不會(huì)出現(xiàn)重復(fù)。若將OrderID字段設(shè)置為手動(dòng)增長型字段,我們的程序可以由以下幾步來實(shí)現(xiàn):首先調(diào)用存儲(chǔ)過程,獲得一個(gè)OrderID,然后使用這個(gè)OrderID填充Order表與OrderDetail表,最后在事務(wù)保護(hù)下對兩表進(jìn)行更新。
使用手動(dòng)增長型字段作為sql server主鍵在進(jìn)行數(shù)據(jù)庫間數(shù)據(jù)復(fù)制時(shí),可以確保數(shù)據(jù)合并過程中不會(huì)出現(xiàn)鍵值沖突,只要我們?yōu)椴煌臄?shù)據(jù)庫分配不同的主鍵取值段就行了。但是,使用手動(dòng)增長型字段會(huì)增加網(wǎng)絡(luò)的RoundTrip,我們必須通過增加一次數(shù)據(jù)庫訪問來獲取當(dāng)前主鍵鍵值,這會(huì)增加網(wǎng)絡(luò)和數(shù)據(jù)庫的負(fù)載,當(dāng)處于一個(gè)低速或斷開的網(wǎng)絡(luò)環(huán)境中時(shí),這種做法會(huì)有很大的弊端。同時(shí),手工維護(hù)主鍵還要考慮并發(fā)沖突等種種因素,這更會(huì)增加系統(tǒng)的復(fù)雜程度。
【編輯推薦】