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

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

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

一、添加外鍵

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

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

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

方法四:在表的定義外進(jìn)行添加

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

二、添加主鍵

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

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

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

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

復(fù)合鍵這樣設(shè)置:

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;

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

alter table(表名) modify id integer auto_increment

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

alter (表名) DROP PRIMARY KEY

外鍵的基本要求

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

外鍵約束

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

約束的基本概念

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

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

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

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

約束模式有三種:

1.district:嚴(yán)格模式,默認(rèn)的,不允許操作

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

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

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

通常在進(jìn)行約束的時候,需要指定操作: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í)行以上操作后,學(xué)生表my_student class_id原來值為4字段現(xiàn)在全部為空

約束的作用

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

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

總結(jié) 

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

相關(guān)文章

  • 解讀mysql中的null問題

    解讀mysql中的null問題

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

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

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

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

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

    mysql游標(biāo)的原理與用法實例分析

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

    mysql約束和高級sql詳解

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

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

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

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

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

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

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

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

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

    MySQL 可擴(kuò)展設(shè)計的基本原則

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

最新評論