SQL約束 pk unique foreign key

約束

* 概念: 對錶中的數據進行限定,保證數據的正確性、有效性和完整性。	
* 分類:
	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. 注意:
		* 唯一約束可以有NULL值,但是隻能有一條記錄爲null
	2. 在創建表時,添加唯一約束
		CREATE TABLE stu(
			id INT,
			phone_number VARCHAR(20) UNIQUE -- 手機號
		);
	3. 刪除唯一約束
		ALTER TABLE stu DROP INDEX phone_number;
	4. 在表創建完後,添加唯一約束
		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 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章