1.外鍵的作用,主要有兩個(gè):
成都創(chuàng)新互聯(lián)專注于彭州網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供彭州營(yíng)銷型網(wǎng)站建設(shè),彭州網(wǎng)站制作、彭州網(wǎng)頁(yè)設(shè)計(jì)、彭州網(wǎng)站官網(wǎng)定制、微信小程序定制開(kāi)發(fā)服務(wù),打造彭州網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供彭州網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(wù)。
一個(gè)是讓數(shù)據(jù)庫(kù)自己通過(guò)外鍵來(lái)保證數(shù)據(jù)的完整性和一致性
一個(gè)就是能夠增加ER圖的可讀性
2.外鍵的配置
1)先創(chuàng)建一個(gè)主表,代碼如下:
#創(chuàng)建表student,并添加各種約束
create table student
(
id int primary key , #主鍵約束
name varchar(20) , #唯一約束
age int NOT NULL, #非空約束
sex varchar(2) ,
address varchar(20) default '重慶' #默認(rèn)約束
) ;
再通過(guò)一個(gè)外鍵,創(chuàng)建一個(gè)分?jǐn)?shù)表,這樣的話,就可以方便查詢。代碼如下:
#創(chuàng)建分?jǐn)?shù)表
create table score
(
id int primary key ,
sid int ,
china int ,
history int,
english int,
constraint FK_sid foreign key(sid) references student(id) #通過(guò)外鍵創(chuàng)建鏈接
) ;
創(chuàng)建外鍵的方法有很多,其中最常見(jiàn)創(chuàng)建外鍵的格式是:constraint FK_*** foreign key(**) references 鏈接的外表
刪除外鍵:
alter table drop foreign key '外鍵名'.
注意:
只有在定義外鍵時(shí),用constraint 外鍵名 foreign key .... 方便進(jìn)行外鍵的刪除
主鍵是唯一標(biāo)示這一行的,就好像你的身份證號(hào)一樣,每個(gè)人只有一個(gè),也是唯一能證明你是你的東西。外鍵是別人執(zhí)行你的東西。也就是說(shuō)如果一個(gè)人想和你有點(diǎn)關(guān)系怎么辦,那就要關(guān)聯(lián)起來(lái),怎么關(guān)聯(lián)起來(lái),就通過(guò)外鍵啊
定義主鍵和外鍵主要是為了維護(hù)關(guān)系數(shù)據(jù)庫(kù)的完整性,總結(jié)一下:
一、主鍵是能確定一條記錄的唯一標(biāo)識(shí),比如,一條記錄包括身份正號(hào),姓名,年齡。身份證號(hào)是唯一能確定你這個(gè)人的,其他都可能有重復(fù),所以,身份證號(hào)是主鍵。
外鍵用于與另一張表的關(guān)聯(lián)。是能確定另一張表記錄的字段,用于保持?jǐn)?shù)據(jù)的一致性。比如,A表中的一個(gè)字段,是B表的主鍵,那他就可以是A表的外鍵。
1、打開(kāi)navicat工具,連接上mysql服務(wù)器,選擇完數(shù)據(jù)庫(kù)之后,選擇一個(gè)表右擊選擇設(shè)計(jì)表(這里為了演示測(cè)試,隨便選擇一個(gè)表即可)。
2、在設(shè)計(jì)表頁(yè)面,可以看到當(dāng)前表的所有字段信息,我們選擇的學(xué)生表有一個(gè)id字段,目前該表沒(méi)有主鍵字段。
3、如圖,在最后一列右擊選擇主鍵,即可將該字段設(shè)置為主鍵,也可以直接點(diǎn)擊鼠標(biāo)左鍵,可以快速添加和取消主鍵。
4、設(shè)置完主鍵之后,可以看到一把鎖的標(biāo)志,并且有一個(gè)1字,因?yàn)橐粋€(gè)表可以給多個(gè)字段添加主鍵,則為聯(lián)合主鍵,這樣就顯示為主鍵1,主鍵2等。
5、主鍵設(shè)置完成之后,還沒(méi)有自增,選擇id字段之后,在下方,如圖,勾選自動(dòng)遞增,這樣id在每次插入記錄之后都會(huì)自增一個(gè)值。
6、設(shè)置完成主鍵和自增之后,點(diǎn)擊保存,關(guān)閉當(dāng)前窗口,然后選擇表名右擊選擇對(duì)象信息。
7、在DLL頁(yè)面中,可以看到剛剛添加的主鍵和自增的DLL語(yǔ)句,這里就是創(chuàng)建表的DLL語(yǔ)句。
8、上面有提到聯(lián)合主鍵,其實(shí)一個(gè)表可以給多個(gè)字段設(shè)置主鍵,這樣可以組成聯(lián)合主鍵,對(duì)于特定的業(yè)務(wù),聯(lián)合主鍵也是必須的。
MySQL 提供了多種創(chuàng)建索引的方法:
1) 使用 CREATE INDEX 語(yǔ)句
可以使用專門(mén)用于創(chuàng)建索引的 CREATE INDEX 語(yǔ)句在一個(gè)已有的表上創(chuàng)建索引,但該語(yǔ)句不能創(chuàng)建主鍵。
語(yǔ)法格式:
CREATE 索引名 ON 表名 (列名 [長(zhǎng)度] [ ASC | DESC])
語(yǔ)法說(shuō)明如下:
索引名:指定索引名。一個(gè)表可以創(chuàng)建多個(gè)索引,但每個(gè)索引在該表中的名稱是唯一的。
表名:指定要?jiǎng)?chuàng)建索引的表名。
列名:指定要?jiǎng)?chuàng)建索引的列名。通??梢钥紤]將查詢語(yǔ)句中在 JOIN 子句和 WHERE 子句里經(jīng)常出現(xiàn)的列作為索引列。
長(zhǎng)度:可選項(xiàng)。指定使用列前的 length 個(gè)字符來(lái)創(chuàng)建索引。使用列的一部分創(chuàng)建索引有利于減小索引文件的大小,節(jié)省索引列所占的空間。在某些情況下,只能對(duì)列的前綴進(jìn)行索引。索引列的長(zhǎng)度有一個(gè)最大上限 255 個(gè)字節(jié)(MyISAM 和 InnoDB 表的最大上限為 1000 個(gè)字節(jié)),如果索引列的長(zhǎng)度超過(guò)了這個(gè)上限,就只能用列的前綴進(jìn)行索引。另外,BLOB 或 TEXT 類型的列也必須使用前綴索引。
ASC|DESC:可選項(xiàng)。ASC指定索引按照升序來(lái)排列,DESC指定索引按照降序來(lái)排列,默認(rèn)為ASC。
2) 使用 CREATE TABLE 語(yǔ)句
索引也可以在創(chuàng)建表(CREATE TABLE)的同時(shí)創(chuàng)建。在 CREATE TABLE 語(yǔ)句中添加以下語(yǔ)句。語(yǔ)法格式:
CONSTRAINT PRIMARY KEY [索引類型] (列名,…)
在 CREATE TABLE 語(yǔ)句中添加此語(yǔ)句,表示在創(chuàng)建新表的同時(shí)創(chuàng)建該表的主鍵。
語(yǔ)法格式:
KEY | INDEX [索引名] [索引類型] (列名,…)
在 CREATE TABLE 語(yǔ)句中添加此語(yǔ)句,表示在創(chuàng)建新表的同時(shí)創(chuàng)建該表的索引。
語(yǔ)法格式:
UNIQUE [ INDEX | KEY] [索引名] [索引類型] (列名,…)
在 CREATE TABLE 語(yǔ)句中添加此語(yǔ)句,表示在創(chuàng)建新表的同時(shí)創(chuàng)建該表的唯一性索引。
語(yǔ)法格式:
FOREIGN KEY 索引名 列名
在 CREATE TABLE 語(yǔ)句中添加此語(yǔ)句,表示在創(chuàng)建新表的同時(shí)創(chuàng)建該表的外鍵。
在使用 CREATE TABLE 語(yǔ)句定義列選項(xiàng)的時(shí)候,可以通過(guò)直接在某個(gè)列定義后面添加 PRIMARY KEY 的方式創(chuàng)建主鍵。而當(dāng)主鍵是由多個(gè)列組成的多列索引時(shí),則不能使用這種方法,只能用在語(yǔ)句的最后加上一個(gè) PRIMARY KRY(列名,…) 子句的方式來(lái)實(shí)現(xiàn)。
1.主鍵語(yǔ)法
①創(chuàng)建時(shí):create table sc (
studentno int,
courseid int,
score int,
primary key (studentno) );
②修改時(shí):ALTER TABLE table_name ADD CONSTRAINT pk_name PRIMARY KEY(列名);
前提是原先沒(méi)有設(shè)置主鍵。
2.外鍵語(yǔ)法
①創(chuàng)建時(shí):create table sc (
studentno int,
courseid int,
score int,
foreign key (courseid) );
②修改時(shí):
ALTER TABLE news_info[子表名] ADD CONSTRAINT FK_news_info_news_type[約束名] FOREIGN KEY (info_id)[子表列] REFERENCES news_type[主表名] (id)[主表列] ;
3.使用組合主鍵
如果一列不能唯一區(qū)分一個(gè)表里的記錄時(shí),可以考慮多個(gè)列組合起來(lái)達(dá)到區(qū)分表記錄的唯一性,形式
①創(chuàng)建時(shí):create table sc (
studentno int,
courseid int,
score int,
primary key (studentno,courseid) );
②修改時(shí):alter table tb_name add primary key (字段1,字段2,字段3);
前提是原來(lái)表中沒(méi)有設(shè)置主鍵,若原先已有主鍵則會(huì)報(bào)錯(cuò)。
mysql設(shè)置UUID為主鍵需要先將數(shù)據(jù)類型設(shè)置為VARCHAR(36),然后插入數(shù)據(jù)的時(shí)候用UUID函數(shù)插入U(xiǎn)UID。下面我用win10系統(tǒng)下的CMD命令行具體演示一下:
1、打開(kāi)CMD,輸入mysql -uroot -p命令連接mysql,如下圖所示
2、通過(guò)create創(chuàng)建表,指定ID為varchar(36),并設(shè)置為主鍵,如下圖所示
3、在插入數(shù)據(jù)的時(shí)候,調(diào)用uuid()函數(shù)往主鍵字段里插入uuid值,如下圖所示
4、最后查詢插入的數(shù)據(jù)就可以看到id主鍵列存放的是uuid類型了,如下圖所示