mysql添加外鍵:
創(chuàng)新互聯(lián)建站主營天門網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,app軟件開發(fā),天門h5成都小程序開發(fā)搭建,天門網(wǎng)站營銷推廣歡迎天門等地區(qū)企業(yè)咨詢
為已經(jīng)添加好的數(shù)據(jù)表添加外鍵:
語法:alter table 表名 add constraint FK_ID foreign key(你的外鍵字段名) REFERENCES 外表表名(對應的表的主鍵字段名);
例: alter table tb_active add constraint FK_ID foreign key(user_id) REFERENCES tb_user(id)
//FK_ID是外鍵的名稱
/*
CREATE TABLE `tb_active` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`title` varchar(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,
`content` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,
`user_id` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `user_id` (`user_id`),
KEY `user_id_2` (`user_id`),
CONSTRAINT `FK_ID` FOREIGN KEY (`user_id`) REFERENCES `tb_user` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
*/
主鍵:唯一標識表中的所有行的一個列或一組列。主鍵不允許空值。不能存在具有相同的主鍵值的兩個行,因此主鍵值總是唯一標識單個行。表中可以有不止一個鍵唯一標識行,每個鍵都稱作候選鍵。只有一個候選鍵可以選作表的主鍵,所有其它候選鍵稱作備用鍵。盡管表不要求具有主鍵,但定義主鍵是很好的做法。 在規(guī)范化的表中,每行中的所有數(shù)據(jù)值都完全依賴于主鍵。例如,在以 EmployeeID 作為主鍵的規(guī)范化的 employee 表中,所有列都應包含與某個特定職員相關的數(shù)據(jù)。該表不具有 DepartmentName 列,因為部門的名稱依賴于部門 ID,而不是職員 ID。 外鍵:外鍵 (FK) 是用于建立和加強兩個表數(shù)據(jù)之間的鏈接的一列或多列。通過將保存表中主鍵值的一列或多列添加到另一個表中,可創(chuàng)建兩個表之間的鏈接。這個列就成為第二個表的外鍵。 Create database cat go use cat go CREATE TABLE s(s# int not null primary key,s_name varchar(8) not null) go CREATE TABLE c (c# int not null primary key,c_name varchar(8) not null) go CREATE TABLE cs(c# int not null,s# int not null,cj tinyint not null default(0), primary key (c#,s#),foreign key(s#) references s(s#),foreign key(c#) references c(c#)) go insert s values(1,'saa') insert c values(1,'caa') --這句是對的 insert cs values(1,1,86) --這句是錯的,sql會報錯,應為s表的s#列里沒有2 insert cs vlaues(2,1,45) 定義主鍵來強制不允許空值的指定列中輸入值的唯一性。如果在數(shù)據(jù)庫中為表定義了主鍵,則可將該表與其它表相關,從而減少冗余數(shù)據(jù)。表只能有一個主鍵。 外鍵。 當創(chuàng)建或更改表時可通過定義 FOREIGN KEY 約束來創(chuàng)建外鍵。 例如,數(shù)據(jù)庫 pubs 中的 titles 表與 publishers 表有鏈接,因為在書名和出版商之間存在邏輯聯(lián)系。titles 表中的 pub_id 列與 publishers 表中的主鍵列相對應。titles 表中的 pub_id 列是到 publishers 表的外鍵。 FOREIGN KEY 約束并不僅僅只可以與另一表的 PRIMARY KEY 約束相鏈接,它還可以定義為引用另一表的 UNIQUE 約束。FOREIGN KEY 約束不允許空值,但是,如果任何組合 FOREIGN KEY 約束的列包含空值,則將跳過 FOREIGN KEY 約束的校驗。 主鍵是本表的唯一標識,而外鍵是與另一個表相關聯(lián)
SQL中PK是指主鍵,F(xiàn)K是指外鍵. \r\n\r\n一、主鍵與外鍵\r\n1.主鍵是用來唯一地標識一行數(shù)據(jù)。主鍵列必須包含唯一的值,且不能包含空值(null)。\r\n2.主鍵可以建立在每張二維表中單列或者多列上。\r\n3.一張二維表上的外鍵可以引用另一張二維表上對應的主鍵。\r\n主鍵會有鑰匙標識,如下圖中紅色圓圈內(nèi)所示,外鍵沒有該標識:\r\n\r\n拓展資料:\r\n下面的 SQL 在 "Persons" 表創(chuàng)建時在 "Id_P" 列創(chuàng)建 PK(主鍵) 約束:\r\nMySQL:\r\nCREATE TABLE Persons\r\n(\r\nId_P int NOT NULL,\r\nLastName varchar(255) NOT NULL,\r\nFirstName varchar(255),\r\nAddress varchar(255),\r\nCity varchar(255),PRIMARY KEY (Id_P))
create
table
volunteer(
志愿者編號
varchar(6)
not
null,
志愿者姓名
varchar(8),
班級編號
varchar(4),
constraint
PK_V
primary
key
(志愿者編號));
create
table
class(
班級編號
varchar(4),
班級名稱
varchar(20),
學院
varchar(20),
constraint
PK_C
primary
key(班級編號),
班級編號
varchar
foreign
key
references
volunteer(班級編號));
你這個試下,我試了可以的
希望可以幫到你
SQL
創(chuàng)建外鍵語句的方法:constraint
外鍵名字
foreign
key
references
外鍵表(外鍵字段)
primary key是主鍵, not null 是值不能為空, foreign key是外鍵,numeric是枚舉類型。
constraint dept_fk foreign key(coll_id) references college(coll_id)指的是表dept_fk的外鍵coll_id參照college表中的coll_id。用來建立兩個表之間的關聯(lián)關系。
其實不止是mysql里,所有的數(shù)據(jù)庫都有主鍵外鍵的概念。舉個簡單的例子。
因為在中國有不少人姓名相同,所以雖然在你家里能用名字做統(tǒng)一標識,但是在中國這個范圍卻不行,所以就有了身份證號,這是主鍵,保證每一個人有一個。
然后你會上學,上學的話就有學籍這么個東西,雖然有學籍號還有學籍信息,但是我現(xiàn)在想要通過身份證號知道你的學歷的話,在學籍這個表中,就要加入你的身份信息,這個身份信息與學籍信息當然不是在一個表里的,最簡單的方法,是把身份信息都復制到學籍信息這個表里,不過很顯然,這樣數(shù)據(jù)庫就有兩份記錄,一份在身份信息表里,一份在學籍信息表里,而且都是身份信息。這叫做冗余,不但占多了空間,還不能保證修改時候的同步,而且你也許還有社會保險啦,駕駛證之類更多的信息存在,我也不可能每個表都復制身份信息過去。這時就出現(xiàn)在外鍵,我只需要在這些表中插入身份證號這個列做為外鍵,那我到時候通過這個唯一的編號去身份信息這個表里找就好了,而且修改身份信息的話也只要在身份信息這個表做就好了,很方便很簡單不是嗎
網(wǎng)站題目:mysql里fk怎么表示 mysql fk
文章URL:http://newbst.com/article44/docpoee.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供虛擬主機、企業(yè)建站、標簽優(yōu)化、定制網(wǎng)站、自適應網(wǎng)站、關鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)