首頁 > 資料庫 > mysql教程 > mysql中restrict是什麼意思

mysql中restrict是什麼意思

青灯夜游
發布: 2023-04-13 15:34:22
原創
4087 人瀏覽過

在mysql中,restrict是約束的意思,是指對錶中資料的一種限制,能夠幫助資料庫管理員更好地管理資料庫,並且能夠確保資料庫中資料的正確性、有效性和完整性。 MySQL支援6種約束:主鍵約束、外鍵約束、唯一約束、檢查約束、非空約束和預設值約束。

mysql中restrict是什麼意思

本教學操作環境:windows7系統、mysql8版本、Dell G3電腦。

在mysql中,restrict是約束的意思。

MySQL中什麼是約束?

restrict(約束)是指對錶中資料的一種限制,能夠幫助資料庫管理員更好地管理資料庫,並且能夠確保資料庫中資料的正確性、有效性和完整性。

例如,在資料表中存放年齡的值時,如果存入 200、300 這些無效的值就毫無意義了。因此,使用約束來限定表中的資料範圍是很有必要的。

MySQL中的限制就是用來偵測資料正確性和合理性的,一般的錯誤有:1,存在相同重複的資料;2,錯誤的資料;3,資料遺失錯誤(空資料) ;4,指稱不明確的錯誤(表之間無法準確聯繫)等。

MySQL的限制就是用來解決上述問題的,例如身分證字號不能重複,收貨地址不能空。如果違反了約束,則資料操作行為被制止。

在 MySQL 中,主要支援以下 6 個限制:

1)主鍵約束

主鍵約束是使用最頻繁的限制。在設計資料表時,一般情況下,會要求表中設定一個主鍵。

主鍵是表的一個特殊字段,該字段能唯一標識該表中的每個資訊。例如,學生資訊表中的學號是唯一的。

2)外鍵約束

外鍵約束經常和主鍵約束一起使用,用來確保資料的一致性。

例如,一個水果攤,只有蘋果、桃子、李子、西瓜 4 種水果,那麼,你來到水果攤要買水果只能選擇蘋果、桃子、李子和西瓜,不能購買其它的水果。

3)唯一約束

唯一約束與主鍵約束有一個相似的地方,就是它們都能夠確保列的唯一性。與主鍵約束不同的是,唯一約束在一個表中可以有多個,並且設定唯一約束的列是允許有空值的,雖然只能有一個空值。

例如,在使用者資訊表中,要避免表中的使用者名稱重名,就可以把使用者名列設定為唯一約束。

4)檢查約束

檢查約束是用來檢查資料表中,欄位值是否有效的一個手段。

例如,學生資訊表中的年齡欄位是沒有負數的,數值也是有限制的。如果是大學生,年齡一般應該在 18~30 歲之間。在設定欄位的檢查約束時要根據實際情況進行設置,這樣能夠減少無效資料的輸入。

5)非空約束

非空約束用來約束表中的欄位不能為空。例如,在學生資訊表中,如果不添加學生姓名,那麼這條記錄是沒有用的。

6)預設值約束

預設值約束用來約束當資料表中某個欄位不輸入值時,自動為其新增一個已經設定好的值。

例如,在註冊學生資訊時,如果不輸入學生的性別,那麼就會預設一個性別或輸入一個「未知」。

預設值約束通常用在已經設定了非空約束的資料列,這樣能夠防止資料表在輸入資料時發生錯誤。

以上 6 種約束條件中,​​一個資料表中只能有一個主鍵約束,其它約束可以有多個。

作業表的限制

1、在表格中加上主鍵限制

        一張表格的只能有一個主鍵,新增主鍵有兩種方式。

        單一主鍵:使用一列作為主鍵列,當此列的值重複時,違反唯一限制。
        組合主鍵:使用多個資料列作為主鍵列,當多個資料列的值都相同時,則違反唯一限制。指的是:使用多個列的組合形式來決定主鍵,當出現組合重複就無效,如00,01,10,11,12,22這樣的組合形式。

        使用DDL語句新增主鍵約束。範例:

ALTER TABLE 表名 ADD PRIMARY KEY(列名);
alter table emp add primary key(employee_id);//选取employee_id作为主键
alter table emp add primary key(employee_id,shenfen_id);//联合主键
登入後複製

2、在表格中加入自成長主鍵限制

        auto_increment。資料庫管理系統自動維護表時自動加上的主鍵,利用自然數自增的方式決定主鍵。同樣的,自增長主鍵也是把某一列當作主鍵。當表中新增了主鍵的欄位增加了數據,則主鍵自動加1。

        自成長主鍵與一般主鍵約束可以互相轉換。

       1, 一個表格中只能有一個列為自動成長。 2,自動增長的列的類型必須是整數類型。 3,自動增長只能加入到具備主鍵約束唯一性約束的列上。 4,刪除主鍵約束或唯一性約束,如果該列擁有自動增長能力,則需要先去掉自動增長然後在刪除約束。

        注意點:如果先前為某個欄位新增了自成長屬性,刪除此欄位時要先刪除自成長屬性。

alter table 表名 modify 主键 类型 auto_increment;
alter table emp modify employee_id int auto_increment;
登入後複製

        或在Navicat中加入主鍵:

mysql中restrict是什麼意思

3、刪除一張表中的主鍵限制

#        使用#DDL語句刪除主鍵。

ALTER TABLE 表名 DROP PRIMARY KEY;
alter table emp drop primary key;
登入後複製

        注意:主鍵刪除主鍵時,若主鍵列具備自動成長能力,需先移除自動成長,再移除主鍵。

alter table emp modify employee_id int;//去掉自增长,与添加自增长代码地区别就是没有auto_increament
alter table emp drop primary key;
登入後複製

4、在一張表上加上外鍵約束

        #使用DDL語句新增外鍵約束。可以給一張表設定多個外鍵。

ALTER  TABLE 表名 ADD CONSTRAINT 约束名 FOREIGN  KEY(列名) REFERENCES 参照的表名(参照的列名);
alter table emp add constraint emp_fk
foreign key(dept_id) references
departments(department_id);
登入後複製

        或在Navicat中新增外鍵。外鍵名稱常使用:表名_fk,表名_fk1表示。

mysql中restrict是什麼意思

5、刪除一張表的外鍵約束

        使用DDL 語句刪除外鍵約束。或在Navicat中主動刪除外鍵。
ALTER TABLE 表名 DROP FOREIGN KEY 约束名;
alter table emp drop foreign key emp_fk;
登入後複製

mysql中restrict是什麼意思

6、给表中某字段添加唯一性约束

        使用DDL语句添加唯一性约束。或在在Navicat中添加唯一性约束。

ALTER TABLE 表名 ADD CONSTRAINT 约束名 UNIQUE(列名);
alter table emp add constraint emp_uk unique(name);
登入後複製

mysql中restrict是什麼意思

7、删除表中某字段的唯一性约束

        使用DDL语句删除唯一性约束。删除之前需要弄清楚删除的约束名是对哪一个字段进行约束的。

ALTER TABLE 表名 DROP KEY 约束名;
alter table emp drop key emp_uk;
登入後複製

8、给表中某个字段添加非空约束

        使用DDL语句添加非空约束。或者Navicat。

ALTER TABLE 表名 MODIFY 列名 类型 NOT NULL;
alter table emp modify salary float(8,2) not NULL;
登入後複製

mysql中restrict是什麼意思

9、删除表中某个字段的非空约束

        使用DDL语句删除非空约束。

ALTER TABLE 表名 MODIFY 列名 类型 NULL;
alter table emp modify salary float(8,2) NULL;
登入後複製

mysql中restrict是什麼意思

创建表的时候添加约束

        上面介绍了当一张表已经存在之后如何添加约束。下面介绍在一开始新建表的时候如何添加约束。

1、查询表中加了哪些约束?

 SHOW KEYS FROM 表名;
登入後複製

2、创建表时添加约束

        创建 depts 表包含 department_id 该列为主键且自动增长,department_name 列不允许重复,location_id 列不允含有空值。

create table depts
(
department_id int primary key auto_increment,
department_name varchar(30) unique,
location_id int not null;
);
登入後複製

【相关推荐:mysql视频教程

以上是mysql中restrict是什麼意思的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板