亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一文理解MySQL數據庫的約束與表的設計

 更新時間:2022年11月15日 11:39:13   作者:Node_Hao  
約束是用來限制表中的數據長什么樣子的,即什么樣的數據可以插入到表中,什么樣的數據插入不到表中,下面這篇文章主要給大家介紹了關于如何通過一文理解MySQL數據庫的約束與表的設計的相關資料,需要的朋友可以參考下

1.數據庫約束

約束是關系型數據庫提供的一種校驗數據合法性的機制. 

1.1 約束類型

約束類型說明示例
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;
外鍵約束關聯(lián)其他表的主鍵或唯一鍵foreign key (字段名) references 主表(列)
check約束保證列的值符合指定的條件check(sex='男'or sex='女')

1.2 null 約束

創(chuàng)建表時指定某列不為空.

語法:

create table 表名(字段1 類型 not null,字段2 類型...);

示例:

1.3 unique 唯一的約束

創(chuàng)建表時指定某列為唯一的不重復的.

語法:

create table 表名(字段1 類型 unique,字段2 類型....);

示例:

1.4 default 默認值約束

指定列為空時的默認值

語法:

create table 表名(字段1 類型 default 默認值,字段2 類型....);

示例:

1.5 primary key 主鍵約束

創(chuàng)建表時指定列有唯一確定的標識符

語法:

create table 表名(字段1 類型 parmary key,字段2 類型...);

示例:

學生id 不為null 且不能重復.

1.6 primary key auto_increment 自增主鍵

對于整數類型的主鍵, 常搭配自增auto_increment變?yōu)樽栽鲋麈I, 插入字段不給值時, 使用最  大值+1.

語法:

create table 表名(字段1 int primary key auto_increment,字段2 類型...);

示例:

分布式系統(tǒng)中唯一id生成算法 

對于較小的數據量, 所有的數據都在一臺MySQL服務器上存儲,此時自增主鍵可以很好的工作, 但如果涉及的數據量較為龐大, 需要將數據部署到多臺MySQL服務器上, 這時再插入數據就無法保證自增主鍵的唯一性.因此MySQL內部采用分布式系統(tǒng)中唯一id生成算法.

實現(xiàn)公式:

時間戳+主機編號+隨機因子 結合這三部分就可以得到一個全局唯一的id.

1.7 foreign key 外鍵約束

MySQL外鍵是用來在兩個表之間建立連接,可以是一列或多列,一個表可以有多個外鍵.

  • 外鍵是本表的一個字段, 不是本表的主鍵, 但對于另一個表的主鍵.
  • 定義外鍵之后不允許刪除另一個表中具有關聯(lián)關系的行.
  • 主表(父表): 相關聯(lián)字段中主鍵所在的表就是主表.
  • 從表(子表): 相關聯(lián)字段中外鍵所在的表就是從表.

語法:

添加外鍵約束

(constraint 外鍵名) foreign key (字段名1),(字段名2..) reference 主表名(主鍵列1,主鍵列2..)

修改表時添加外鍵約束 

alter table 表名 add (constraint 外鍵名) foreign key (列名) references 主表名(列名);

刪除外鍵約束

alter table 表名 drop forigen key (外鍵名);

示例:

MySQL表中, 沒有默認對兩張有關聯(lián)的表提供檢查機制, 例如:下圖中插入非法班級, 不會報錯. 因此需要引入外鍵約束.

加入外鍵約束之后再插入非法數據就會報錯. 

非法修改已插入的數據也會報錯.

Tips:

  • 父表必須已存在數據庫中或是當前正在創(chuàng)建的表.
  • 父表中的主鍵不能出現(xiàn)空值, 但外鍵可以.所以通常用primary key來約束主鍵.
  • 外鍵中列是數目和數據類型必須和父表的主鍵一一對應.
  • 父表限制子表的插入,字表也約束父表的刪除.(互相制約) 

父表中元素的刪除:

實際應用中刪除父表中數據的方式通常是邏輯刪除. 當一個商品下架之后, 為了讓客戶可以查看到歷史訂單, 所以不能直接刪除商品信息. 通常需要在建表之初預留商品下架的字段, 商品下架之后, 給商品下架的字段標記賦值達到偽刪除的效果.

2.表的設計

基本思路:

  • 先明確實體
  • 再明確實體之間的聯(lián)系
  • 根據上述內容, 嵌套到下面的公式中, 就可做出表.

示例:

粗略設計一個學生教務管理系統(tǒng).

  • 確定實體為: 學生, 課程, 學生賬號, 學生班級
  • 學生與課程之間存在關系, 學生與賬號之間存在關系, 學生與班級之間存在關系.
  • 學生與課程:多對多, 學生與賬號:一對一, 學生與班級:一對多.

2.1 一對一

一個人只能有一個身份證號碼, 一個身份證號碼只對應一個人.

2.2 一對多

一個班級有多個學生, 一個學生只對應一個班級.

2.3 多對多

一個學生可以選擇多個課程, 一個課程也可以被多個學生選擇.

總結

到此這篇關于一文理解MySQL數據庫的約束與表設計的文章就介紹到這了,更多相關MySQL約束與表設計內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論