概念: 對錶中的數據進行限定,保證數據的正確性、有效性和完整性。mysql
1. 主鍵約束:primary key 2. 非空約束:not null 3. 惟一約束:unique 4. 外鍵約束:foreign key
1. 建立表時添加約束 CREATE TABLE stu( id INT, NAME VARCHAR(20) NOT NULL -- name爲非空 ); 2. 建立表完後,添加非空約束 ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL; 3. 刪除name的非空約束 ALTER TABLE stu MODIFY NAME VARCHAR(20);
1.建立表時,添加惟一約束sql
CREATE TABLE stu( id INT, phone_number VARCHAR(20) UNIQUE -- 添加了惟一約束 ); * 注意mysql中,惟一約束限定的列的值能夠有多個null
ALTER TABLE stu DROP INDEX phone_number;code
在建立表後,添加惟一約束索引
ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE; !!:若是添加約束前存在相同值,添加語句執行後會報錯
1.注意:rem
1.含義:非空且惟一 2.一張表只能有一個字段爲主鍵 3.主鍵就是表中記錄的惟一標識
2.在建立表時,添加主鍵約束table
create table stu( id int primary key,-- 給id添加主鍵約束 name varchar(20) );
3.刪除主鍵語法
-- 錯誤 alter table stu modify id int ; ALTER TABLE stu DROP PRIMARY KEY;
4.建立完表後,添加主鍵im
ALTER TABLE stu MODIFY id INT PRIMARY KEY;
5.自動增加:數據
1. 概念:若是某一列是數值類型的,使用 auto_increment 能夠來完成值得自動增加 2. 在建立表時,添加主鍵約束,而且完成主鍵自增加 create table stu( id int primary key auto_increment,-- 給id添加主鍵約束 name varchar(20) ); 3.刪除自動增加(由於主鍵用MODIFY刪不了) ALTER TABLE stu MODIFY id INT; 4.添加自動增加 ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;
讓表於表產生關係,從而保證數據的正確性。(外鍵列值能夠爲NULL,但不能爲另外一張表中沒有的值)tab
1. 在建立表時,能夠添加外鍵 * 語法: create table 表名( .... 外鍵列 constraint 外鍵名稱 foreign key (外鍵列名稱) references 主表名稱(主表列名稱) ); 2. 刪除外鍵 ALTER TABLE 表名 DROP FOREIGN KEY 外鍵名稱; 3. 建立表以後,添加外鍵 ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵字段名稱) REFERENCES 主表名稱(主表列名稱); 4. 級聯操做 1. 添加級聯操做 語法:ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵字段名稱) REFERENCES 主表名稱(主表列名稱) ON UPDATE CASCADE ON DELETE CASCADE ; 2. 分類: 1. 級聯更新:ON UPDATE CASCADE 2. 級聯刪除:ON DELETE CASCADE