MySQL 約束

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

      1. 主鍵約束:primary key
      2. 非空約束:not null
      3. 惟一約束:unique
      4. 外鍵約束:foreign key
    • 非空約束:not null,值不能爲nullsql

      1. 建立表時添加約束
        CREATE TABLE stu(
        id INT,
        NAME VARCHAR(20) NOT NULL -- name爲非空
        );rem

      2. 建立表完後,添加非空約束
        ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL;table

      3. 刪除name的非空約束
        ALTER TABLE stu MODIFY NAME VARCHAR(20);語法

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

      1. 建立表時,添加惟一約束
        CREATE TABLE stu(
        id INT,
        phone_number VARCHAR(20) UNIQUE -- 添加了惟一約束數據

        );tab

        • 注意mysql中,惟一約束限定的列的值能夠有多個null
      2. 刪除惟一約束di

        ALTER TABLE stu DROP INDEX phone_number;co

      3. 在建立表後,添加惟一約束
        ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;

    • 主鍵約束:primary key。

      1. 注意:

        1. 含義:非空且惟一
        2. 一張表只能有一個字段爲主鍵
        3. 主鍵就是表中記錄的惟一標識
      2. 在建立表時,添加主鍵約束
        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. 建立完表後,添加主鍵
        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. 刪除自動增加
          ALTER TABLE stu MODIFY id INT;

        4. 添加自動增加
          ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;

    • 外鍵約束:foreign key,讓表於表產生關係,從而保證數據的正確性。

      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
相關文章
相關標籤/搜索