3.三種主要的數據模型
實(shí)際DBMS所支持的數據模型主要有三種:
層次模型(Hierarchical Model)
網(wǎng)狀模型(Network Model)
關(guān)系模型(Relational Model)其中,關(guān)系模型是當前DBMS所支持的數據模型的主流。90年代運行的DBMS幾乎都是基于關(guān)系模型的。層次模型和網(wǎng)狀模型統稱(chēng)為非關(guān)系模型。非關(guān)系模型的結構可以和圖論中的圖相對應,比較直觀(guān),但在理論上不完備,實(shí)現效率較低,故此目前很少用。但是最近,層次模型在研究面向對象的DBMS中已得到重視。在關(guān)系模型中,數據在用戶(hù)的觀(guān)點(diǎn)中(或在用戶(hù)視圖中)的邏輯結構是一張二維表(Table)。
關(guān)系(Relation),對應于平常講的一張表。
元組(Tuple),表中的一行。
屬性(Attribute),表中的一列稱(chēng)為一個(gè)屬性,給每一列起一個(gè)名,稱(chēng)為屬性名。這一列或這個(gè)屬性所有可能取的值的集合稱(chēng)為這個(gè)屬性的值域(Domain),值域中的一個(gè)元素叫做這個(gè)屬性的值。
主關(guān)鍵字(Primary Key Attribute或Primary Key),是指能唯一標識一個(gè)元組的一個(gè)或一組屬性。
分量(Attribute value),是指元組中的一個(gè)屬性值。
關(guān)系模式(Relational Schema),是對關(guān)系的描述,一般用關(guān)系名(屬性名1,屬性名2,…,屬性名n)來(lái)表示。同層次模型和網(wǎng)狀模型相比較,關(guān)系模型具有下列特點(diǎn):
(1)概念單一 在關(guān)系模型中,無(wú)論是實(shí)體還是實(shí)體之間的聯(lián)系都用關(guān)系來(lái)表示。在關(guān)系模型中,在用戶(hù)的觀(guān)點(diǎn)中,數據的邏輯結構就是表,也只有這唯一的概念。在非關(guān)系模型中,用戶(hù)要區分記錄型與記錄型之間的聯(lián)系兩個(gè)概念;當環(huán)境復雜時(shí),數據結構異常復雜,難以掌握。而關(guān)系模型,由于概念單一,可以變復雜為直觀(guān)、簡(jiǎn)單,易學(xué)易用。
(2)規范化 所謂關(guān)系規范化是指在關(guān)系模型中,每一個(gè)關(guān)系都要滿(mǎn)足一定的條件要求。這些條件被稱(chēng)為規范條件。對于關(guān)系,一個(gè)最基本的規范條件是,要求關(guān)系中的每一個(gè)屬性(或分量)均是不可分的數據項;也就是說(shuō)不允許表中有表,表是不可嵌套的。
(3)在關(guān)系模型中,用戶(hù)對數據的操作的輸入和輸出都是表,也就是說(shuō),用戶(hù)通過(guò)操作舊表而得到一張新表?傊,關(guān)系模型概念簡(jiǎn)單,結構清晰,用戶(hù)易學(xué)易用,有嚴格的以數學(xué)為基礎的關(guān)系理論作指導,便于DBMS的實(shí)現;陉P(guān)系的DBMS簡(jiǎn)化了應用程序員的工作,便于數據庫應用系統的設計和維護。故此,關(guān)系模型自誕生以后就得到了迅速的發(fā)展,成為應用最為廣泛的、唯一的數據模型。
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |