欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql給一張表添加外鍵的4種方法

 更新時間:2023年08月05日 15:54:20   作者:子非魚@Itfuture  
這篇文章主要給大家介紹了關于mysql給一張表添加外鍵的4種方法,MySQL是一種常用的關系型數(shù)據(jù)庫管理系統(tǒng),它支持外鍵約束以保證數(shù)據(jù)庫的數(shù)據(jù)完整性,需要的朋友可以參考下

一、添加外鍵

添加外鍵約束名字一定不能重復
如何添加外鍵

方法一:直接在屬性值后面添加

create table score(
cscore int(11),
st_id int(50) references student(id),
cs_id int(30) references classes(id),
primary key(st_id,cs_id)
);

方法二:

create table score(
cscore int(11),
st_id int(50),
cs_id int(30),
primary key(st_id,cs_id),
FOREIGN KEY (st_id) REFERENCES student(id),
FOREIGN KEY (cs_id) REFERENCES classes(id)
);

方法三:添加約束

create table score(
cscore int(11),
st_id int(50),
cs_id int(30),
primary key(st_id,cs_id),
CONSTRAINT `FK_ID_ST` FOREIGN KEY (st_id) REFERENCES student(id),
CONSTRAINT `FK_ID_CS` FOREIGN KEY (cs_id) REFERENCES classes(id)
);

方法四:在表的定義外進行添加

alter table 表名 add constraint FK_ID foreign key(你的外鍵字段名) REFERENCES 外表表名(對應的表的主鍵字段名);

二、添加主鍵

1.創(chuàng)建表的時候直接在表字段后,跟primary key關鍵字。(一張表有且只能有一個主鍵,主鍵具有唯一性。)

CREATE TABLE tb
(
id INT IDENTITY(1,1) PRIMARY KEY,
name VARCHAR(20)
)

2.在創(chuàng)建表的時候在所有字段后面使用primary key(主鍵字段列表)來創(chuàng)建主鍵(如果有多個字段作為主鍵被稱為復合主鍵)

*CREATE TABLE table_test(
id INT NOT NULL,
name VARCHAR(20) NOT NULL,
address VARCHAR(20),
PRIMARY KEY(id)
);

復合鍵這樣設置:

CREATE TABLE table_test(
user_id INT NOT NULL,
user_name VARCHAR(20) NOT NULL,
user_address VARCHAR(20),
PRIMARY KEY (user_id, user_name)
);*

3.在表創(chuàng)建好之后添加主鍵(表本身沒有主鍵):

alter table 表名 add primary key(字段列表)
ALTER TABLE Employees
ADD CONSTRAINT PK_EmployeesID PRIMARY KEY (EmployeeID)

給表中沒有的字段添加主鍵:

ALTER TABLE (表名) ADD id INT(16) NOT NULL
PRIMARY KEY AUTO_INCREMENT FIRST;

注:主鍵必須非空,自增需要自己設置。如下:

alter table(表名) modify id integer auto_increment

我們光說了添加主鍵,那么刪除主鍵怎么辦?

alter (表名) DROP PRIMARY KEY

外鍵的基本要求

  1. 外鍵字段需要保證與關聯(lián)的主表的主鍵字段類型完全一致
  2. 基本屬性也要相同
  3. 如果是在表后增加外鍵,對數(shù)據(jù)還有一定要求(從表數(shù)據(jù)與主表的關聯(lián)關系)
  4. 外鍵只能使用InnoDB存儲引擎

外鍵約束

外鍵約束:通過建立外鍵關系之后,對主表和從表都會有一定的數(shù)據(jù)約束效率。

約束的基本概念

當一個外鍵產生時:外鍵所在的表(從表)會受制于主表數(shù)據(jù)的存在從而導致數(shù)據(jù)不能進行某些不符合規(guī)范的操作(不能插入主表不存在的數(shù)據(jù));

如果一張表被其他表外鍵引入,那么該表的數(shù)據(jù)操作就不能隨意;必須保證從表數(shù)據(jù)的有效性(不能隨便刪除一個被從表引入的記錄)
外鍵約束的概念

可以在創(chuàng)建外鍵約束的時候,對外鍵進行約束操作。

基本語法:add foreign key(外鍵字段) references 主表(主鍵) on 約束模式

約束模式有三種:

1.district:嚴格模式,默認的,不允許操作

2.cascade:級聯(lián)模式,一起操作,主表變化,從表數(shù)據(jù)跟著變化

3.set null:置空模式,主表變化(刪除),從表對應記錄設置為空:前提是從表中對應外鍵字段允許為空。

外鍵約束主要約束的對象是主表操作:從表就是不能插入主表不存在的數(shù)據(jù)

通常在進行約束的時候,需要指定操作:update 和 delete

常用的約束模式:on update cascade,on delete set null,更新級聯(lián),刪除置空

# 更新模式
alter table my_student add foreign key(class_id)
references my_class(class_id)
-- 約束條件
on update cascade
on delete set null;
-- 更新主表
update my_class set class_id = 4 where class_id = 2;
-- 執(zhí)行更新主表操作后,從表也隨便主表的變化而變化了
#刪除模式
delete from my_class where class_id = 4;
-- 執(zhí)行以上操作后,學生表my_student class_id原來值為4字段現(xiàn)在全部為空

約束的作用

保證數(shù)據(jù)的完整性:主表與從表的數(shù)據(jù)要一致

正因為外鍵有非常強大的數(shù)據(jù)約束作用,而且可能導致數(shù)據(jù)在后臺變化的不可控。導致程序在進行設計開發(fā)邏輯的時候,
沒有辦法去很好的把握數(shù)據(jù)(業(yè)務),所以外鍵比較少用

總結 

到此這篇關于mysql給一張表添加外鍵的4種方法的文章就介紹到這了,更多相關mysql給表添加外鍵內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 解讀mysql中的null問題

    解讀mysql中的null問題

    這篇文章主要介紹了解讀mysql中的null問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • 使用mysqldump導入數(shù)據(jù)和mysqldump增量備份(mysqldump使用方法)

    使用mysqldump導入數(shù)據(jù)和mysqldump增量備份(mysqldump使用方法)

    mysqldump常用于MySQL數(shù)據(jù)庫邏輯備份,下面看實例吧
    2013-12-12
  • mysql正確刪除數(shù)據(jù)的方法(drop,delete,truncate)

    mysql正確刪除數(shù)據(jù)的方法(drop,delete,truncate)

    這篇文章主要給大家介紹了關于mysql正確刪除數(shù)據(jù)的相關資料,DELETE語句是MySQL中最常用的刪除數(shù)據(jù)的方式之一,但也有幾種其他方法來實現(xiàn),需要的朋友可以參考下
    2023-10-10
  • mysql游標的原理與用法實例分析

    mysql游標的原理與用法實例分析

    這篇文章主要介紹了mysql游標的原理與用法,結合實例形式分析了mysql游標的概念、原理、用法及操作注意事項,需要的朋友可以參考下
    2020-04-04
  • mysql約束和高級sql詳解

    mysql約束和高級sql詳解

    文章介紹了MySQL中的約束類型(如主鍵、外鍵、唯一約束、非空約束、檢查約束、默認值和自增)以及高級SQL功能(如子查詢、連接、事務和存儲過程),感興趣的朋友一起看看吧
    2024-11-11
  • mysql函數(shù)之截取字符串的實現(xiàn)

    mysql函數(shù)之截取字符串的實現(xiàn)

    本文主要介紹了mysql函數(shù)之截取字符串的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • 解決MySQL 5.7中定位DDL被阻塞的問題

    解決MySQL 5.7中定位DDL被阻塞的問題

    這篇文章主要介紹了MySQL 5.7中如何定位DDL被阻塞的問題,在MySQL 5.7中,針對MDL,引入了一張新表performance_schema.metadata_locks,該表可對外展示MDL的相關信息,包括其作用對象,類型及持有等待情況。對此問題感興趣的朋友參考下本文
    2018-08-08
  • 分析Mysql大量數(shù)據(jù)導入遇到的問題以及解決方案

    分析Mysql大量數(shù)據(jù)導入遇到的問題以及解決方案

    這篇文章主要介紹了Mysql大量數(shù)據(jù)導入遇到的問題以及解決方案,希望我們整理的內容能夠幫助到大家。
    2018-02-02
  • MySQL 表字段太多超長問題解決方案

    MySQL 表字段太多超長問題解決方案

    在設計MySQL數(shù)據(jù)庫時,常遇到表字段超長問題,這是由字段數(shù)量過多或字段定義過長引起的,MySQL對字段數(shù)量和行大小有嚴格限制,超過限制將無法正常操作,本文就來介紹一下解決方法,感興趣的可以了解一下
    2024-10-10
  • MySQL 可擴展設計的基本原則

    MySQL 可擴展設計的基本原則

    可擴展設計是一個非常復雜的系統(tǒng)工程,所涉及的各個方面非常的廣泛,技術也較為復雜,可能還會帶來很多其他方面的問題。但不管我們如何設計,不管遇到哪些問題,有些原則我們還是必須確保的。
    2021-05-05

最新評論