什麼是鍵資料庫
❶ 資料庫中什麼是主鍵,什麼是外鍵
主鍵(Primary key): 也稱為主碼或主關鍵字,用於惟一地確定一個元組的屬性或屬性組(復合主碼)。每個關系都有一個並且只有一個主碼。
外鍵(Foreign Key):也稱為外碼或外部關鍵字。如果一個屬性集不是所在關系的關鍵字,但是是其他關系的關鍵字,則該屬性集稱為外部關鍵字。
在關系資料庫中可以通過外鍵使兩個關系關聯,這種聯系通常是一對多(1:n)的,其中主(父)關系(1方)稱為被參照關系,從(子)關系(n方)稱為參照關系。
(1)什麼是鍵資料庫擴展閱讀:
資料庫主鍵作用:
1、保證實體的完整性
2、加快資料庫的操作速度
3、在表中添加新記錄時,DBMS會自動檢查新記錄的主鍵值,不允許該值與其他記錄的主鍵值重復。
4、DBMS自動按主鍵值的順序顯示表中的記錄。如果沒有定義主鍵,則按輸入記錄的順序顯示表中的記錄。
在有些資料庫中,雖然主鍵不是必需的,但最好為每個表都設置一個主鍵,不管是單主鍵還是復合主鍵。它存在代表著表結構的完整性,表的記錄必須得有唯一區分的欄位,主鍵主要是用於其他表的外鍵關聯,以及本記錄的修改與刪除。
❷ 資料庫中鍵的定義和作用
生活中每個人都有自己的特徵,用於區別其他人,比如姓名,身份證號,因為姓名可能有重復,區分每個人的時候都使用身份證號,比如辦銀行卡需要對應本人的身份證號,這樣可以把銀行卡跟人關聯起來。
資料庫中的數據(表示某個事物或對象)也是同樣,為了區分數據,類似人的身份證號,為數據定義一個鍵,跟身份證號一樣,這個鍵作用多多:比如可以確定這個數據跟其他數據是不一樣的,另外通過鍵可以跟其他類型數據關聯起來,用於其他復雜用途比如復雜查詢等
❸ 什麼是資料庫裡面的主鍵
資料庫主鍵的意思是指一個列或者是多列的組合,它的值能唯一地標識表中的每一行,它的作用是可強製表的實體完整性。主鍵用於其他表的外鍵關聯,以及本記錄的修改與刪除。在創建以及更改表的時候可以通過定義 PRIMARY KEY 約束來進行主鍵的創建。
(3)什麼是鍵資料庫擴展閱讀:
資料庫主鍵的作用如下:
1、可以保證實體的完整性。
2、加快資料庫的操作速度。
3、在表中添加新記錄時,DBMS會自動檢查新記錄的主鍵值。
4、DBMS自動按主鍵值的順序顯示表中的記錄。
❹ 資料庫中的鍵、主碼、主鍵是什麼意思
碼(鍵):代表數目的符號
主碼也就是主鍵,是惟一標識表中的每一行的欄位或者多個欄位的組合,它可以實現表的實體完整性
每個表只能有惟一的主碼,且不能為空
這需要理清幾個概念:
1)候選鍵: 關系中的一個屬性組,其值能唯一標識一個元組,若從該屬性組中去掉任何一個屬性,它就不具有這一性質了,這樣的屬性組稱作候選碼。
2)主鍵:當有多個候選碼時,可以選定一個作為主碼,選定的候選碼稱主鍵
3)外鍵: 關系R中的一個屬性組,它不是R的候選碼,但它與另一個關系S的候選碼相對應,則稱這個屬性組為R的外碼或外鍵。
舉個例子:
有兩個關系:
student(s#,sname,d#),即學生這個關系有三個屬性:學號,姓名,所在系別
dep(d#,dname),即院系有兩個屬性:系號、系名
則s#、d#是主鍵,也是各自所在關系的唯一候選鍵,d#是student的外鍵
❺ 「文檔資料庫和鍵值資料庫」有什麼區別
如何選擇鍵值型資料庫(key-value
databases)?
鍵值資料庫適用於那些頻繁讀寫,擁有簡單數據模型的應用。鍵值資料庫中存儲的值可以是簡單的標量值,如整數或布爾值,也可以是結構化數據類型,比如列表和JSON結構。
鍵值資料庫通常具有簡單的查詢功能,允許你通過鍵來查找一個值。一般鍵值資料庫都支持搜索功能,這提供了更高的靈活性。開發人員可以選擇使用一些技巧,比如用枚舉鍵來實現范圍查詢,但這些資料庫通常缺乏對於文檔、列族、圖形資料庫的查詢功能。
鍵值資料庫廣泛應用於以下類型的應用:
從關系型資料庫緩存數據來用於提高性能
對Web應用暫時性數據的追蹤,例如購物車數據等
存儲配置和用戶數據信息的移動應用
需要存儲圖片和音頻文件等較大對象的應用
如何選擇文檔型資料庫(document
databases)?
文檔型資料庫按照靈活性的標准設計。如果一個應用程序需要存儲不同的屬性以及大量的數據,那麼文檔資料庫將會是一個很好的選擇。例如,要在關系資料庫中表示產品,建模者可以使用通用的屬性和額外的表來為每個產品子類型存儲屬性。文檔資料庫卻可以更為簡單的處理這種情況。
文檔資料庫提供嵌入式文檔,這對於非規范化非常有用。文檔資料庫將經常查詢的數據存儲在同一個文檔中,而不是存儲在不同的表中。
此外,文檔資料庫改善了鍵值資料庫的查詢功能和文檔中基於屬性的過濾功能。
由於其靈活性、高性能和易用性,文檔資料庫可能是目前最受歡迎的NoSQL資料庫。
這些資料庫適用於如下一些用例,包括:
用於後台具有大量讀寫操作的網站
管理數據類型和變數屬性,比如產品
跟蹤元數據的變數類型
使用JSON數據結構的應用
使用類似結構套結構等非規范化數據的應用程序
微軟Azure和Cloudant等雲服務資料庫同樣提供了文檔型資料庫。
❻ 資料庫主鍵具體指哪項,有什麼作用
主鍵:
關系資料庫依賴於主鍵---它是資料庫物理模式的基石。主鍵在物理層面上只有兩個用途:
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中存在。
❼ 資料庫鍵的含義
關鍵字(Key)
關鍵字是關系模型中的一個重要概念,它是邏輯結構,不是資料庫的物理部分。
候選關鍵字(Candidate Key)
如果一個屬性集能惟一地標識表的一行而又不含多餘的屬性,那麼這個屬性集稱為候選關鍵字。
主關鍵字(Primary Key)
主關鍵字是被挑選出來,作表的行的惟一標識的侯選關鍵字。一個表只有一個主關鍵字。主關鍵字又可以稱為主鍵。
公共關鍵字(Common Key)
在關系資料庫中,關系之間的聯系是通過相容或相同的屬性或屬性組來表示的。如果兩個關系中具有相容或相同的屬性或屬性組,那麼這個屬性或屬性組被稱為這兩個關系的公共關鍵字。
如有一個表,欄位為:
id firstname lastname address phone IDcard
那麼id或IDcard或firstname+lastname都可以說是關鍵字。
其中id為主關鍵字,IDcard和firstname+lastname為候選關鍵字
外關鍵字(Foreign Key)
如果公共關鍵字在一個關系中是主關鍵字,那麼這個公共關鍵字被稱為另一個關系的外關鍵字。由此可見,外關鍵字表示了兩個關系之間的聯系。以另一個關系的外關鍵字作主關鍵字的表被稱為主表,具有此外關鍵字的表被稱為主表的從表。外關鍵字又稱作外鍵。
表A:id firstname lastname address classid
表B:classid classname
classid是表B的主鍵,在表A中有一個欄位和表B中的classid關聯,所以,classid 是表B的外鍵
❽ 資料庫中鍵是什麼意思,請解釋下鍵、主碼、主鍵等名稱,謝謝了
碼(鍵):代表數目的符號 主碼也就是主鍵,是惟一標識表中的每一行的欄位或者多個欄位的組合,它可以實現表的實體完整性 每個表只能有惟一的主碼,且不能為空 這需要理清幾個概念: 1)候選鍵: 關系中的一個屬性組,其值能唯一標識一個元組,若從該屬性組中去掉任何一個屬性,它就不具有這一性質了,這樣的屬性組稱作候選碼。 2)主鍵:當有多個候選碼時,可以選定一個作為主碼,選定的候選碼稱主鍵 3)外鍵: 關系R中的一個屬性組,它不是R的候選碼,但它與另一個關系S的候選碼相對應,則稱這個屬性組為R的外碼或外鍵。 舉個例子: 有兩個關系: student(s#,sname,d#),即學生這個關系有三個屬性:學號,姓名,所在系別 dep(d#,dname),即院系有兩個屬性:系號、系名 則s#、d#是主鍵,也是各自所在關系的唯一候選鍵,d#是student的外鍵
❾ 資料庫全鍵是什麼
全鍵,也稱全碼。
是關系模型的所有屬性組是這個關系模式的候選鍵。
❿ 資料庫裡面的主鍵和外鍵及候選鍵是什麼意思啊
1、主鍵(primary
key)吧:一張表(關系)的一個列(屬性)或多個列可以作為主鍵,但是前提是讓這個列作主鍵,這個列就能保證該列下的各個行(元組)的值不能相同,比如說用姓名屬性作主鍵的話,那麼這個主鍵就不一定可以,如果有兩個人是同樣的名字的話,就不能做到該屬性下的各個元組數據的值不同,如果用阿拉伯數字作主鍵就是一個很好的選擇。
2、外鍵(foreign
key):一張表(關系)的列(屬性)它同時存在表1和表2中,它不是表1的主鍵,而是表2的主鍵,就可以說他是表1的外鍵。
3、候選鍵(Candidate
Key):能唯一標識表(關系)中行(元組)的列(屬性),則稱該屬性為候選鍵,也稱
候選關鍵字
或
候選碼;由此來看候選鍵可以不只一個,還看一看得出的就是主鍵同時它也是候選鍵。