資料庫建表關系
『壹』 按先後次序例舉建立資料庫表和關系的步驟
創建步驟如下:
1、打開Access資料庫,建立兩個數據表;
2、選中任何一個表,然後點擊工具欄上的視圖圖標,;
3、切換到設計界面,點擊工具欄上的【關系】按鈕,打開關系窗口,;
4、在關系窗口的【添加表】中,依次選擇要添加的表,然後點擊添加按鈕,將表添加到關系窗口中。添加好以後點擊關閉,回到關系窗口;
5、滑鼠點擊其中一個表的主鍵欄位,即沒有重復值的唯一欄位。按住滑鼠不放,然後拖動到另一個表的相同欄位松開,在彈出的窗口中點擊創建即可,。
『貳』 Access怎麼建立數據表間的關系
1、首先,在打開Access資料庫之後,我們創建兩個數據表作為示例。
『叄』 在access資料庫中創建表間關系的步驟
1、打開資料庫,在「資料庫工具」欄中點擊「關系」按鈕。
2、系統會彈出提示,進行表的添加,選中要建立關系的表,點擊添加。
提示不會自動關閉,需要再點擊「關閉」按鈕來關掉它。
3、通過用滑鼠拖動就可以完成關系的建立,比如我拖動「學生信息」表中的學號,到「課程成績」表裡學號的位置。
4、彈出「編輯關系」對話框,點擊「創建」按鈕,這樣就建立了兩表間的關系。
5、其表現形式是一條折線將其連在一起。同樣我們也可以創建「課程成績」表與「課程信息」表之間的關系。選中的關系會是較粗的線。
6、刪除關系。在選中的關繫上(就是線上)右擊,可以刪除這個關系。
7、參照完整性。關系可以設定參照完整性,這樣你在其中一個表中更改或刪除記錄時,將同步到另一個表。
8、系統默認下並沒有開啟關系的參照完整性。在「編輯關系」對話框中,勾選「實施參照完整性」,再根據需要勾選下面兩個選項,可以實施它。
『肆』 資料庫為什麼要建立表間關系
建立關系,是因為這兩個實體之間本來就存在關系。就像「學生」必須有一個自己的「班級」,「老師」必須有「課程」這些實體之間本來就存在關聯,為了在查詢資料庫時候,能跟據一個表的數據查詢到另一個表的數據,(比如我知道這個學生的編號,我就可以查詢該學生所在的班級,但是這是兩個獨立的表,要是能夠建立關系,就需要把班級編號也放入學生表)所以就要建立表之間的關系。
『伍』 請問資料庫在創建表的時候如何設計表關系,一對一,一對多,多對多 請高手舉例說明。謝謝!!!
多對多關系至少需要3個表,我們把一個表叫做主表,一個叫做關系表,另外一個叫做字典表或者副表(字典表是紀錄比較少,而且基本穩定的,例如:版塊名稱;副表是內容比較多,內容變化的,例如)。
按照資料庫的增刪查改操作,多對多關系的查找都可以用inner join或者
select * from 主表 where id in (select 主表id from 關系表)
1,角色任命型
特點:關系表兩外鍵組合無重復紀錄,關系表一般不需要時間欄位和主鍵,有一個表是字典類型的表。
界面特點:顯示主表,用checkbox或多選select設置多選關系。
例如:任命版主(用戶表-關系表-版塊名稱表),角色許可權控制等,用戶是5個版塊版主,只要關系表5行紀錄就可以確立,關系表的兩個外鍵具有聯合主鍵性質。
增加關系:如果沒有組合紀錄,insert之。
刪除關系:如果有組合紀錄,刪除之。
2,集合分組型
特點:同角色任命型類似,關系表兩外鍵組合無重復紀錄,關系表一般不需要時間欄位和主鍵。區別是主副表都不是字典表,可能都很大不固定。
界面特點:顯示主表,用搜索代替簡單的checkbox或多選select,或者一條一條的添加。
例如:歌曲專集(專集表-關系表-歌曲表)。手機分組(分組表-關系表-手機表)。用戶圈子(圈子表-關系表-用戶表)。文章標簽(文章表-關系表-標簽表)
增加關系:同版主任命型。
刪除關系:同版主任命型。
3,明細帳型
特點:關系表可以有重復紀錄,關系表一般有時間欄位,有主鍵,可能還有文字型的欄位用來說明每次發生關系的原因(消費)。
界面特點:顯示關系表,用radio或下拉設置單選關系。
例如:現金消費明細帳或訂單(用戶表-訂單表-消費原因表),用戶可能多次在同一事情上重復消費。積分變化紀錄也屬於這類。
增加關系:不管有沒有組合紀錄,insert之,紀錄時間。
刪除關系:根據關系表PK刪除。
4,評論回復型
特點:同明細帳型關系表一般有時間欄位,有主鍵,區別是重點在文字型的欄位用來說明每次發生關系的內容(評論回復)。
界面特點:回復文本框。
例如:論壇回復(用戶表-回復表-帖子表),用戶可能多次在不同帖子上評論回復費。
增加關系:不管有沒有組合紀錄,insert之,紀錄時間和文字。
刪除關系:根據關系表(回復表)PK刪除。
5,站內簡訊型
特點:主副表是同一個,關系表一般有時間欄位,有主鍵,重點在關系表文字型的欄位用來說明每次發生關系的內容(消息)或者其他標記位來表示文字已讀狀態時間等。
界面特點:回復文本框。
例如:站內簡訊(用戶表-簡訊表-用戶表),用戶可能給用戶群發或者單發,有標記位來表示文字已讀狀態時間等。
增加關系:不管有沒有組合紀錄,insert之,紀錄時間和文字。
刪除關系:根據關系表(回復表)PK刪除。
6,用戶好友型
特點:主副表是同一個,同集合分組型,關系表兩外鍵組合無重復紀錄,關系表一般不需要時間欄位和主鍵。
界面特點:同集合分組型,顯示主表,用搜索代替簡單的checkbox或多選select,或者一條一條的添加。
例如:下載站點的文件,(文件表-關系表-文件表)可以被軟體工具打開,軟體工具本身也是一種文件,可以被下載。用戶的好友,也是用戶(用戶表-好友關系表-用戶表)
增加關系:同版主任命型。
刪除關系:同版主任命型
『陸』 資料庫表與表之間的關系
表與表之間一般存在三種關系,即一對一,一對多,多對多關系。
例如:一個人可以擁有多輛汽車,要求查詢某個人擁有的所有車輛。
分析:這種情況其實也可以採用 一張表,但因為一個人可以擁有多輛汽車,如果採用一張表,會造成冗餘信息過多。好的設計方式是,人和車輛分別單獨建表,那麼如何將兩個表關聯呢?有個巧妙的方法,在車輛的表中加個外鍵欄位(人的編號)即可。
例如:學生選課,一個學生可以選修多門課程,每門課程可供多個學生選擇。
分析:這種方式可以按照類似一對多方式建表,但冗餘信息太多,好的方式是實體和關系分離並單獨建表,實體表為學生表和課程表,關系表為選修表,其中關系表採用聯合主鍵的方式(由學生表主鍵和課程表主鍵組成)建表。
什麼是視圖?
在 SQL 中,視圖是基於 SQL 語句的結果集的可視化的表。
第一點:
使用視圖,可以定製用戶數據,聚焦特定的數據。
解釋:
在實際過程中,公司有不同角色的工作人員,我們以銷售公司為例的話,
采購人員,可以需要一些與其有關的數據,而與他無關的數據,對他沒
有任何意義,我們可以根據這一實際情況,專門為采購人員創建一個視
圖,以後他在查詢數據時,只需select * from view_caigou 就可以啦。
第二點:使用視圖,可以簡化數據操作。
解釋:我們在使用查詢時,在很多時候我們要使用聚合函數,同時還要
顯示其它欄位的信息,可能還會需要關聯到其它表,這時寫的語句可能
會很長,如果這個動作頻繁發生的話,我們可以創建視圖,這以後,我
們只需要select * from view1就可以啦~,是不是很方便呀~
第三點:使用視圖,基表中的數據就有了一定的安全性
因為視圖是虛擬的,物理上是不存在的,只是存儲了數據的集合,我們可以
將基表中重要的欄位信息,可以不通過視圖給用戶,視圖是動態的數據的集
合,數據是隨著基表的更新而更新。同時,用戶對視圖,不可以隨意的更改
和刪除,可以保證數據的安全性。
第四點:可以合並分離的數據,創建分區視圖
隨著社會的發展,公司的業務量的不斷的擴大,一個大公司,下屬都設有很
多的分公司,為了管理方便,我們需要統一表的結構,定期查看各公司業務
情況,而分別看各個公司的數據很不方便,沒有很好的可比性,如果將這些
數據合並為一個表格里,就方便多啦,這時我們就可以使用union關鍵字,
將各分公司的數據合並為一個視圖。
以上,就是我認為視圖的作用,實際上很多公司都使用視圖來查詢數據的。
內連接: 只連接匹配的行
SELECT * from gradeclass gc inner join grade g on gc.grade_id=g.Id,
左外連接: 包含左邊表的全部行(不管右邊的表中是否存在與它們匹配的行),以及右邊表中全部匹配的行
select * from grade g rigth OUTER JOIN gradeclass g on g.grade_id=gc.Id(這里的outer可以省略)
右外連接: 包含右邊表的全部行(不管左邊的表中是否存在與它們匹配的行),以及左邊表中全部匹配的行
select * from grade g rigth OUTER JOIN gradeclass g on g.grade_id=gc.Id(這里的outer可以省略)
全外連接: 包含左、右兩個表的全部行,不管另外一邊的表中是否存在與它們匹配的行。
交叉連接: 生成笛卡爾積-它不使用任何匹配或者選取條件,而是直接將一個數據源中的每個行與另一個數據源的每個行都一一匹配