分類:mysql
非空約束:not null,值不能爲nullsql
建立表時添加約束
CREATE TABLE stu(
id INT,
NAME VARCHAR(20) NOT NULL -- name爲非空
);rem
建立表完後,添加非空約束
ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL;table
刪除name的非空約束
ALTER TABLE stu MODIFY NAME VARCHAR(20);語法
惟一約束:unique,值不能重複im
建立表時,添加惟一約束
CREATE TABLE stu(
id INT,
phone_number VARCHAR(20) UNIQUE -- 添加了惟一約束數據
);tab
刪除惟一約束di
ALTER TABLE stu DROP INDEX phone_number;co
在建立表後,添加惟一約束
ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;
主鍵約束:primary key。
注意:
在建立表時,添加主鍵約束
create table stu(
id int primary key,-- 給id添加主鍵約束
name varchar(20)
);
刪除主鍵
-- 錯誤 alter table stu modify id int ;
ALTER TABLE stu DROP PRIMARY KEY;
建立完表後,添加主鍵
ALTER TABLE stu MODIFY id INT PRIMARY KEY;
自動增加:
概念:若是某一列是數值類型的,使用 auto_increment 能夠來完成值得自動增加
在建立表時,添加主鍵約束,而且完成主鍵自增加
create table stu(
id int primary key auto_increment,-- 給id添加主鍵約束
name varchar(20)
);
刪除自動增加
ALTER TABLE stu MODIFY id INT;
添加自動增加
ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;
外鍵約束:foreign key,讓表於表產生關係,從而保證數據的正確性。
在建立表時,能夠添加外鍵
刪除外鍵
ALTER TABLE 表名 DROP FOREIGN KEY 外鍵名稱;
建立表以後,添加外鍵
ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵字段名稱) REFERENCES 主表名稱(主表列名稱);
級聯操做