數(shù)據(jù)庫中identity字段不必是系統(tǒng)產(chǎn)生的唯一值 性能優(yōu)化方法(新招)
更新時間:2011年09月05日 20:14:21 作者:
具有identity特性的字段,其值是系統(tǒng)產(chǎn)生的,自動增加的,所以,一般把這個用在一個表的主鍵上。
但是,具有identity特性的字段,不需要具有唯一性,更不必須是主鍵。
可以通過,set identity_insert tablename (on|off),在運行時控制,是否可以在identity字段中指定值,而不是由系統(tǒng)自動的插入值。
那么,這有什么用處呢。舉個例子來說,兩個用戶之間的聊天,可以有多次,這個用一個chatsession來表示。在數(shù)據(jù)庫中,我們需要三個表: user, chatsession(sessionid identity,...), user_chatsession (userid, sessionid, ...), 來表示這個關系。這里面,多出了一個表chatsession, 其主鍵sessionid具有identity特性,并且在user_chatsession中被引用。
但是,我們知道,數(shù)據(jù)庫寫操作比讀操作的開銷要大很多,如果我想做優(yōu)化,把chatsession整個的去掉,那應該怎么做呢.
這時,就會用到我說的這一點。首先把 user_chatsession 中的sesssionid變成identity 字段,在插入一個session中的第一個 user-session (for user a)記錄時,讓系統(tǒng)產(chǎn)生sessionid, 然后記錄下這個sessionid, 在插入一個session中后續(xù)的 user-session (for user b, user c...), 執(zhí)行set identity_insert tablename on,就可以把先前記錄的sessionid值插入。
還有另外一個方法,比較笨一點,就是用 select max(sessionid) + 1 from table where userid = @useridA,來獲得要新插入的sessionid, 這種方法性能上顯然差了許多。
可以通過,set identity_insert tablename (on|off),在運行時控制,是否可以在identity字段中指定值,而不是由系統(tǒng)自動的插入值。
那么,這有什么用處呢。舉個例子來說,兩個用戶之間的聊天,可以有多次,這個用一個chatsession來表示。在數(shù)據(jù)庫中,我們需要三個表: user, chatsession(sessionid identity,...), user_chatsession (userid, sessionid, ...), 來表示這個關系。這里面,多出了一個表chatsession, 其主鍵sessionid具有identity特性,并且在user_chatsession中被引用。
但是,我們知道,數(shù)據(jù)庫寫操作比讀操作的開銷要大很多,如果我想做優(yōu)化,把chatsession整個的去掉,那應該怎么做呢.
這時,就會用到我說的這一點。首先把 user_chatsession 中的sesssionid變成identity 字段,在插入一個session中的第一個 user-session (for user a)記錄時,讓系統(tǒng)產(chǎn)生sessionid, 然后記錄下這個sessionid, 在插入一個session中后續(xù)的 user-session (for user b, user c...), 執(zhí)行set identity_insert tablename on,就可以把先前記錄的sessionid值插入。
還有另外一個方法,比較笨一點,就是用 select max(sessionid) + 1 from table where userid = @useridA,來獲得要新插入的sessionid, 這種方法性能上顯然差了許多。
您可能感興趣的文章:
- Oracle數(shù)據(jù)庫性能優(yōu)化技術(shù)開發(fā)者網(wǎng)絡Oracle
- SQL Server數(shù)據(jù)庫性能優(yōu)化技術(shù)
- SQL Server數(shù)據(jù)庫的高性能優(yōu)化經(jīng)驗總結(jié)
- 數(shù)據(jù)庫性能優(yōu)化三:程序操作優(yōu)化提升性能
- 數(shù)據(jù)庫性能優(yōu)化二:數(shù)據(jù)庫表優(yōu)化提升性能
- 數(shù)據(jù)庫性能優(yōu)化一:數(shù)據(jù)庫自身優(yōu)化提升性能
- MySQL性能優(yōu)化的一些技巧幫助你的數(shù)據(jù)庫
- 解析MySQL數(shù)據(jù)庫性能優(yōu)化的六大技巧
- 數(shù)據(jù)庫訪問性能優(yōu)化
相關文章
SQL Server 遠程連接服務器詳細配置(sp_addlinkedserver)
這篇文章主要介紹了SQL Server 遠程連接服務器詳細配置(sp_addlinkedserver),需要的朋友可以參考下2017-01-01MSSQL漢字轉(zhuǎn)拼音函數(shù)實現(xiàn)語句
漢字轉(zhuǎn)拼音(無數(shù)據(jù)表版) 從獲到拼音函數(shù)得到的一點心得體會2009-09-09sql查詢一個數(shù)組中是否包含某個內(nèi)容find_in_set問題
這篇文章主要介紹了sql查詢一個數(shù)組中是否包含某個內(nèi)容find_in_set問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01SQL SERVER2012中新增函數(shù)之字符串函數(shù)CONCAT詳解
SQL Server 2012有一個新函數(shù),就是CONCAT函數(shù),連接字符串非它莫屬。比如在它出現(xiàn)之前,連接字符串是使用"+"來連接,如遇上NULL,還得設置參數(shù)與配置,不然連接出來的結(jié)果將會是一個NULL。本文就介紹了關于SQL SERVER 2012中CONCAT函數(shù)的相關資料,需要的朋友可以參考。2017-03-03DATASET 與 DATAREADER對象有什么區(qū)別
DataReader和DataSet最大的區(qū)別在于,DataReader使用時始終占用SqlConnection(俗稱:非斷開式連接),在線操作數(shù)據(jù)庫時,任何對SqlConnection的操作都會引發(fā)DataReader的異常。下面同本文對dataset與datareader的區(qū)別詳細學習吧2016-11-11sql ntext數(shù)據(jù)類型字符替換實現(xiàn)代碼
sql ntext數(shù)據(jù)類型字符替換實現(xiàn)代碼,需要的朋友可以參考下。2011-09-09