<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
約束是關係型資料庫提供的一種校驗資料合法性的機制.
約束型別 | 說明 | 範例 |
null | 使用not null 指定列不為空 | name varchar(20) not null; |
unique | 指定列為唯一的,不重複的 | name varchar(20) unique; |
default | 指定列為空時的預設值 | name varchar(20) default "無名氏"; |
主鍵約束 | not null 和unique 的結合 | id int primary key; |
外來鍵約束 | 關聯其他表的主鍵或唯一鍵 | foreign key (欄位名) references 主表(列) |
check約束 | 保證列的值符合指定的條件 | check(sex='男'or sex='女') |
建立表時指定某列不為空.
語法:
create table 表名(欄位1 型別 not null,欄位2 型別...);
範例:
建立表時指定某列為唯一的不重複的.
語法:
create table 表名(欄位1 型別 unique,欄位2 型別....);
範例:
指定列為空時的預設值
語法:
create table 表名(欄位1 型別 default 預設值,欄位2 型別....);
範例:
建立表時指定列有唯一確定的識別符號
語法:
create table 表名(欄位1 型別 parmary key,欄位2 型別...);
範例:
學生id 不為null 且不能重複.
對於整數型別的主鍵, 常搭配自增auto_increment變為自增主鍵, 插入欄位不給值時, 使用最 大值+1.
語法:
create table 表名(欄位1 int primary key auto_increment,欄位2 型別...);
範例:
分散式系統中唯一id生成演演算法
對於較小的資料量, 所有的資料都在一臺MySQL伺服器上儲存,此時自增主鍵可以很好的工作, 但如果涉及的資料量較為龐大, 需要將資料部署到多臺MySQL伺服器上, 這時再插入資料就無法保證自增主鍵的唯一性.因此MySQL內部採用分散式系統中唯一id生成演演算法.
實現公式:
時間戳+主機編號+隨機因子 結合這三部分就可以得到一個全域性唯一的id.
MySQL外來鍵是用來在兩個表之間建立連線,可以是一列或多列,一個表可以有多個外來鍵.
- 外來鍵是本表的一個欄位, 不是本表的主鍵, 但對於另一個表的主鍵.
- 定義外來鍵之後不允許刪除另一個表中具有關聯關係的行.
- 主表(父表): 相關聯欄位中主鍵所在的表就是主表.
- 從表(子表): 相關聯欄位中外來鍵所在的表就是從表.
語法:
新增外來鍵約束
(constraint 外來鍵名) foreign key (欄位名1),(欄位名2..) reference 主表名(主鍵列1,主鍵列2..)
修改表時新增外來鍵約束
alter table 表名 add (constraint 外來鍵名) foreign key (列名) references 主表名(列名);
刪除外來鍵約束
alter table 表名 drop forigen key (外來鍵名);
範例:
MySQL表中, 沒有預設對兩張有關聯的表提供檢查機制, 例如:下圖中插入非法班級, 不會報錯. 因此需要引入外來鍵約束.
加入外來鍵約束之後再插入非法資料就會報錯.
非法修改已插入的資料也會報錯.
Tips:
- 父表必須已存在資料庫中或是當前正在建立的表.
- 父表中的主鍵不能出現空值, 但外來鍵可以.所以通常用primary key來約束主鍵.
- 外來鍵中列是數目和資料型別必須和父表的主鍵一一對應.
- 父表限制子表的插入,字表也約束父表的刪除.(互相制約)
父表中元素的刪除:
實際應用中刪除父表中資料的方式通常是邏輯刪除. 當一個商品下架之後, 為了讓客戶可以檢視到歷史訂單, 所以不能直接刪除商品資訊. 通常需要在建表之初預留商品下架的欄位, 商品下架之後, 給商品下架的欄位標記賦值達到偽刪除的效果.
基本思路:
- 先明確實體
- 再明確實體之間的聯絡
- 根據上述內容, 巢狀到下面的公式中, 就可做出表.
範例:
粗略設計一個學生教務管理系統.
- 確定實體為: 學生, 課程, 學生賬號, 學生班級
- 學生與課程之間存在關係, 學生與賬號之間存在關係, 學生與班級之間存在關係.
- 學生與課程:多對多, 學生與賬號:一對一, 學生與班級:一對多.
一個人只能有一個身份證號碼, 一個身份證號碼只對應一個人.
一個班級有多個學生, 一個學生只對應一個班級.
一個學生可以選擇多個課程, 一個課程也可以被多個學生選擇.
到此這篇關於一文理解MySQL資料庫的約束與表設計的文章就介紹到這了,更多相關MySQL約束與表設計內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45