商城資料庫主鍵用什麼
A. 資料庫中的主鍵有什麼用
資料庫的主鍵是很有必要的,也可以說是必須要有的,資料庫有三個範式,第三個範式是現在比較流行的也是資料庫用的最多的,主鍵能區分數據,使數據唯一,減少數據的冗餘,使資料庫在管理和維護上方便
B. 資料庫主鍵具體指哪項,有什麼作用
主鍵:
關系資料庫依賴於主鍵---它是資料庫物理模式的基石。主鍵在物理層面上只有兩個用途:
1. 惟一地標識一行。
2. 作為一個可以被外鍵有效引用的對象。
基於以上這兩個用途,下面給出了我在設計物理層面的主鍵時所遵循的一些原則:
1. 主鍵應當是對用戶沒有意義的。如果用戶看到了一個表示多對多關系的連接表中的數據,並抱怨它沒有什麼用處,那就證明它的主鍵設計地很好。
2. 主鍵應該是單列的,以便提高連接和篩選操作的效率。
註:使用復合鍵的人通常有兩個理由為自己開脫,而這兩個理由都是錯誤的。其一是主鍵應當具有實際意義,然而,讓主鍵具有意義只不過是給人為地破壞資料庫提供了方便。其二是利用這種方法可以在描述多對多關系的連接表中使用兩個外部鍵來作為主鍵,我也反對這種做法,理由是:復合主鍵常常導致不良的外鍵,即當連接表成為另一個從表的主表,而依據上面的第二種方法成為這個表主鍵的一部分,然,這個表又有可能再成為其它從表的主表,其主鍵又有可能成了其它從表主鍵的一部分,如此傳遞下去,越靠後的從表,其主鍵將會包含越多的列了。
3. 永遠也不要更新主鍵。實際上,因為主鍵除了惟一地標識一行之外,再沒有其他的用途了,所以也就沒有理由去對它更新。如果主鍵需要更新,則說明主鍵應對用戶無意義的原則被違反了。
註:這項原則對於那些經常需要在數據轉換或多資料庫合並時進行數據整理的數據並不適用。
4. 主鍵不應包含動態變化的數據,如時間戳、創建時間列、修改時間列等。
5. 主鍵應當有計算機自動生成。如果由人來對主鍵的創建進行干預,就會使它帶有除了惟一標識一行以外的意義。一旦越過這個界限,就可能產生認為修改主鍵的動機,這樣,這種系統用來鏈接記錄行、管理記錄行的關鍵手段就會落入不了解資料庫設計的人的手中。
外鍵是資料庫一級的一個完整性約束,就是資料庫基礎理論書中所說的「參照完整性」的資料庫實現方式。
外鍵屬性當然是可以去掉的,如果你不想再用這種約束,對編程當然不會有什麼影響,但相應的錄入數據的時候就不對錄入的數據進行「參照完整性」檢查了。
例如有兩個表
A(a,b) :a為主鍵,b為外鍵(來自於B.b)
B(b,c,d) :b為主鍵
如果我把欄位b的外鍵屬性去掉,對編程沒什麼影響。
如上面,A中的b要麼為空,要麼是在B的b中存在的值,有外鍵的時候,資料庫會自動幫你檢查A的b是否在B的b中存在。
C. 做華為商城網站,資料庫需要哪些表,各個表中都需要哪些屬性。
在建立資料庫的抄時候,需要為每張表指定一個主鍵,所謂主鍵就是能夠唯一標識表中某一行的屬性或屬性組,一個表只能有一個主鍵,但可以有多個候選索引。
因為主鍵可以唯一標識某一行記錄,所以可以確保執行數據更新、刪除的時候不會出現張冠李戴的錯誤。
當然,其它欄位可以輔助我們在執行這些操作時消除共享沖突。
主鍵除了上述作用外,常常與外鍵構成參照完整性約束,防止出現數據不一致。
所以資料庫在設計時,主鍵起到了很重要的作用。
常見的資料庫主鍵選取方式有:
自動增長欄位
手動增長欄位
UniqueIdentifier
「COMB」類型
D. 資料庫中的主鍵是什麼
雖然可以不設置主鍵,但是一般來說,一個表中都應該有一個主鍵,它代表了這條記錄的唯一性。很難想像沒有主鍵怎麼建立關系資料庫。
E. 我用sql資料庫,用戶表最好用什麼做主鍵比較好
主鍵是唯一標識一條用戶記錄(用戶名、用戶密碼等)的屬性,不能重名。個人覺得用自定義數字編碼最好(可設置自動編碼)。
F. 資料庫表中的主鍵有什麼作用
資料庫主鍵
主鍵:表中經常有一個列或多列的組合,其值能唯一地標識表中的每一行。這樣的一列或多列稱為表的主鍵,通過它可強製表的實體完整性。當創建或更改表時可通過定義 PRIMARY KEY 約束來創建主鍵。一個表只能有一個 PRIMARY KEY 約束,而且 PRIMARY KEY 約束中的列不能接受空值。由於 PRIMARY KEY 約束確保唯一數據,所以經常用來定義標識列。
作用:
1)保證實體的完整性;
2)加快資料庫的操作速度
3) 在表中添加新記錄時,ACCESS會自動檢查新記錄的主鍵值,不允許該值與其他記錄的主鍵值重復。
4) ACCESS自動按主鍵值的順序顯示表中的記錄。如果沒有定義主鍵,則按輸入記錄的順序顯示表中的記錄。
在有些資料庫中,雖然主鍵不是必需的,但最好為每個表都設置一個主鍵,不管是單主鍵還是復合主鍵。它存在代表著表結構的完整性,表的記錄必須得有唯一區分的欄位,主鍵主要是用於其他表的外鍵關聯,以及本記錄的修改與刪除。
主鍵的無意義性
在開發過程中,讀者可能會看到將一些表使用有意義的欄位表示主鍵,例如「用戶登錄信息表」將「登錄名」(英文名)作為主鍵,「訂單表」中將「訂單編號」作為主鍵,如此設計主鍵一般都是沒什麼問題,因為將這些主鍵基本不具有「意義更改」的可能性。但是,也有一些例外的情況,例如「訂單表」需要支持需求「訂單可以作廢,並重新生成訂單,而且訂單號要保持原訂單號一致」,那將「訂單編號」作為主鍵就滿足不了要求了。因此讀者在使用具有實際意義的欄位作為主鍵時,需要考慮是否存在這種可能性。
主鍵的選擇
①編號作主鍵
此方法就是採用實際業務中的唯一欄位的「編號」作為主鍵設計,這在小型的項目中是推薦這樣做的,因為這可以使項目比較簡單化,但在使用中卻可能帶來一些麻煩,比如要進行「編號修改」時,可能要涉及到很多相關聯的其他表,就像黎叔說的「後果很嚴重」;還有就是上面提到的「業務要求允許編號重復時」,我們再那麼先知,都無法知道業務將會修改成什麼?
②自動編號主鍵
這種方法也是很多朋友在使用的,就是新建一個ID欄位,自動增長,非常方便也滿足主鍵的原則,優點是:資料庫自動編號,速度快,而且是增量增長,聚集型主鍵按順序存放,對於檢索非常有利;數字型的,佔用空間小,易排序,在程序中傳遞也方便;如果通過非系統增加記錄(比如手動錄入,或是用其他工具直接在表裡插入新記錄,或老系統數據導入)時,非常方便,不用擔心主鍵重復問題。
缺點:其實缺點也就是來自其優點,就是因為自動增長,在手動要插入指定ID的記錄時會顯得麻煩,尤其是當系統與其他系統集成時,需要數據導入時,很難保證原系統的ID不發生主鍵沖突(前提是老系統也是數字型的);如果其他系統主鍵不是數字型那就麻煩更大了,會導致修改主鍵數據類型了,這也會導致其他相關表的修改,後果同樣很嚴重;就算其他系統也是數字型的,在導入時,為了區分新老數據,可能想在老數據主鍵前統一加一個「o」(old)來表示這是老數據,那麼自動增長的數字型又面臨一個挑戰。
G. 資料庫主鍵用什麼類型
主鍵設計原則復
1、確保主鍵的制無意義性
要用代理主鍵,不要使用業務主鍵。任何一張表,強烈建議不要使用有業務含義的欄位充當主鍵。我們通常都是在表中單獨添加一個整型的編號充當主鍵欄位。
2、採用整型主鍵
主鍵通常都是整數,不建議使用字元串當主鍵。(如果主鍵是用於集群式服務,可以採用字元串類型)
3、減少主鍵的變動
主鍵的值通常都不允許修改,除非本記錄被刪除
4、避免重復使用主鍵
主鍵的值通常不重用,意味著記錄被刪除後,該主鍵值不再使用。
5、主鍵欄位定義區分
主鍵不要直接定義成【id】,而要加上前綴,定義成【表名id】或者【表名_id】
H. mysql資料庫表用什麼做主鍵
1、主鍵定義
表中經常有一個列或多列的組合,其值能唯一地標識表中的每一行。這樣的一列或多列稱為表的主鍵,通過它可強製表的實體完整性。當創建或更改表時可通過定義 PRIMARY KEY 約束來創建主鍵。一個表只能有一個 PRIMARY KEY 約束,而且 PRIMARY KEY 約束中的列不能接受空值。由於 PRIMARY KEY 約束確保唯一數據,所以經常用來定義標識列。
2、主鍵作用
1)保證實體的完整性;
2)加快資料庫的操作速度
3) 在表中添加新記錄時,資料庫會自動檢查新記錄的主鍵值,不允許該值與其他記錄的主鍵值重復。
4) 資料庫自動按主鍵值的順序顯示表中的記錄。如果沒有定義主鍵,則按輸入記錄的順序顯示表中的記錄。
3、主鍵的必要性
在有些資料庫中,雖然主鍵不是必需的,但最好為每個表都設置一個主鍵,不管是單主鍵還是復合主鍵。它存在代表著表結構的完整性,表的記錄必須得有唯一區分的欄位,主鍵主要是用於其他表的外鍵關聯,以及本記錄的修改與刪除。
4、主鍵的選擇
1)編號作主鍵
此方法就是採用實際業務中的唯一欄位的「編號」作為主鍵設計,這在小型的項目中是推薦這樣做的,因為這可以使項目比較簡單化,但在使用中卻可能帶來一些麻煩,比如要進行「編號修改」時,可能要涉及到很多相關聯的其他表
2)自動編號主鍵
這種方法也是很多人在使用的,就是新建一個ID欄位,自動增長,非常方便也滿足主鍵的原則
a、優點:資料庫自動編號,速度快,而且是增量增長,聚集型主鍵按順序存放,對於檢索非常有利;數字型的,佔用空間小,易排序,在程序中傳遞也方便;如果通過非系統增加記錄(比如手動錄入,或是用其他工具直接在表裡插入新記錄,或老系統數據導入)時,非常方便,不用擔心主鍵重復問題。
b、缺點:其實缺點也就是來自其優點,就是因為自動增長,在手動要插入指定ID的記錄時會顯得麻煩,尤其是當系統與其他系統集成時,需要數據導入時,很難保證原系統的ID不發生主鍵沖突(前提是老系統也是數字型的);如果其他系統主鍵不是數字型那就麻煩更大了,會導致修改主鍵數據類型了,這也會導致其他相關表的修改,後果同樣很嚴重;就算其他系統也是數字型的,在導入時,為了區分新老數據,可能想在老數據主鍵前統一加一個「o」(old)來表示這是老數據,那麼自動增長的數字型又面臨一個挑戰。
3)Max加一
由於自動編號存在那些問題,所以有些人就採用自己生成,同樣是數字型的,只是把自動增長去掉了,採用在Insert時,讀取Max值後加一,這種方法可以避免自動編號的問題,但也存在一個效率問題,如果記錄非常大的話,那麼Max()也會影響效率的;更嚴重的是並發性問題,如果同時有兩人讀到相同的Max後,加一後插入的ID值會重復,這已經是有經驗教訓的了。
4)自製加一
考慮Max加一的效率後,有人採用自製加一,也就是建一個特別的表,欄位為:表名,當前序列值。這樣在往表中插入值時,先從此表中找到相應表的最大值後加一,進行插入,有人可能發現,也可能會存在並發處理,這個並發處理,可以採用lock線程的方式來避免,在生成此值的時,先Lock,取到值以後,再unLock出來,這樣不會有兩人同時生成了。這比Max加一的速度要快多了。但同樣存在一個問題:在與其他系統集成時,脫離了系統中的生成方法後,很麻煩保證自製表中的最大值與導入後的保持一致,而且數字型都存在上面講到的「o」老數據的導入問題。因此在「自製加一」中可以把主鍵設為字元型的。字元型的自製加一中應該字元型主鍵可以應付很多我們意想不到的情況。
5)GUID主鍵
目前一個比較好的主鍵是採用GUID,推薦主鍵還是字元型的,但值由GUID生成,GUID是可以自動生成,也可以程序生成,而且鍵值不可能重復,可以解決系統集成問題,幾個系統的GUID值導到一起時,也不會發生重復,就算有「o」老數據也可以區分,而且效率很高,在.NET里可以直接使用System.Guid.NewGuid()進行生成,在SQL里也可以使用NewID()生成。優點是:
同IDENTITY 列相比,uniqueidentifier 列可以通過NewID() 函數提前得知新增加的行ID,為應用程序的後續處理提供了很大方便。
a、優點:便於資料庫移植,其它資料庫中並不一定具有IDENTITY 列,而Guid 列可以作為字元型列轉換到其它資料庫中,同時將應用程序中產生的GUID 值存入資料庫,它不會對原有數據帶來影響。便於資料庫初始化,如果應用程序要載入一些初始數據,IDENTITY 列的處理方式就比較麻煩,而uniqueidentifier 列則無需任何處理,直接用T-SQL 載入即可。便於對某些對象或常量進行永久標識,如類的ClassID,對象的實例標識,UDDI 中的聯系人、服務介面、tModel標識定義等。
b:缺點是:
GUID 值較長,不容易記憶和輸入,而且這個值是隨機、無順序的
GUID 的值有16 個位元組,與其它那些諸如4 位元組的整數相比要相對大一些。這意味著如果在資料庫中使用uniqueidentifier 鍵,可能會帶來兩方面的消極影響:存儲空間增大;索引時間較慢。
I. 資料庫主鍵 採用哪種方式最好
你想說的是用什麼欄位建主鍵比較好是吧!
J. 資料庫的主鍵應該選擇什麼數據類型比較好
定義:能夠唯一標識一個記錄的欄位或欄位集。
特點:一個表中只能有一個
可以由一個或多個列組成
主鍵
的列不允許設為空(NULL)
表中各數據行在主鍵列不能取重復數據
Image和text類型的列不能設為主鍵