MySQL學習筆記(5) —— 約束

概念: 對錶中的數據進行限定,保證數據的正確性、有效性和完整性。mysql

分類:

1. 主鍵約束:primary key
2. 非空約束:not null
3. 惟一約束:unique
4. 外鍵約束:foreign key

非空約束:not null,值不能爲null

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);

惟一約束:unique,值不能重複

1.建立表時,添加惟一約束sql

CREATE TABLE stu( 
    id INT, 
    phone_number VARCHAR(20) UNIQUE -- 添加了惟一約束
    );
* 注意mysql中,惟一約束限定的列的值能夠有多個null
  1. 刪除惟一約束(惟一索引)

    ALTER TABLE stu DROP INDEX phone_number;code

  2. 在建立表後,添加惟一約束索引

    ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;
    !!:若是添加約束前存在相同值,添加語句執行後會報錯

主鍵約束:primary key。一張表只有一個列爲主鍵

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;

外鍵約束:foreign key

讓表於表產生關係,從而保證數據的正確性。(外鍵列值能夠爲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
相關文章
相關標籤/搜索