這篇文章給大家分享的是有關(guān)MySQL如何將復(fù)合主鍵改為單一主鍵的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。
創(chuàng)新互聯(lián)基于分布式IDC數(shù)據(jù)中心構(gòu)建的平臺(tái)為眾多戶提供電信內(nèi)江機(jī)房 四川大帶寬租用 成都機(jī)柜租用 成都服務(wù)器租用。
所謂的復(fù)合主鍵 就是指你表的主鍵含有一個(gè)以上的字段組成,不使用無(wú)業(yè)務(wù)含義的自增id作為主鍵。
比如
create table test ( name varchar(19), id number, value varchar(10), primary key (name,id) )
上面的name和id字段組合起來(lái)就是你test表的復(fù)合主鍵 ,它的出現(xiàn)是因?yàn)槟愕膎ame字段可能會(huì)出現(xiàn)重名,所以要加上ID字段這樣就可以保證你記錄的唯一性 ,一般情況下,主鍵的字段長(zhǎng)度和字段數(shù)目要越少越好 。
這里就會(huì)有一個(gè)疑惑? 主鍵是唯一的索引,那么為何一個(gè)表可以創(chuàng)建多個(gè)主鍵呢?
其實(shí)“主鍵是唯一的索引”這話有點(diǎn)歧義的。舉個(gè)例子,我們?cè)诒碇袆?chuàng)建了一個(gè)ID字段,自動(dòng)增長(zhǎng),并設(shè)為主鍵,這個(gè)是沒(méi)有問(wèn)題的,因?yàn)椤?strong>主鍵是唯一的索引”,ID自動(dòng)增長(zhǎng)保證了唯一性,所以可以。
此時(shí),我們?cè)賱?chuàng)建一個(gè)字段name,類型為varchar,也設(shè)置為主鍵,你會(huì)發(fā)現(xiàn),在表的多行中你是可以填寫(xiě)相同的name值的,這豈不是有違“主鍵是唯一的索引”這句話么?
所以我才說(shuō)“主鍵是唯一的索引”是有歧義的。應(yīng)該是“當(dāng)表中只有一個(gè)主鍵時(shí),它是唯一的索引;當(dāng)表中有多個(gè)主鍵時(shí),稱為復(fù)合主鍵,復(fù)合主鍵聯(lián)合保證唯一索引”。
為什么自增長(zhǎng)ID已經(jīng)可以作為唯一標(biāo)識(shí)的主鍵,為啥還需要復(fù)合主鍵呢。因?yàn)?,并不是所有的表都要有ID這個(gè)字段,比如,我們建一個(gè)學(xué)生表,沒(méi)有唯一能標(biāo)識(shí)學(xué)生的ID,怎么辦呢,學(xué)生的名字、年齡、班級(jí)都可能重復(fù),無(wú)法使用單個(gè)字段來(lái)唯一標(biāo)識(shí),這時(shí),我們可以將多個(gè)字段設(shè)置為主鍵,形成復(fù)合主鍵,這多個(gè)字段聯(lián)合標(biāo)識(shí)唯一性,其中,某幾個(gè)主鍵字段值出現(xiàn)重復(fù)是沒(méi)有問(wèn)題的,只要不是有多條記錄的所有主鍵值完全一樣,就不算重復(fù)。
怎么把復(fù)合主鍵改為單一主鍵
一個(gè)表只能有一個(gè)主鍵:
基于一列的主鍵:
alter table test add constraint PK_TEST primary key(ename);
基于多列的聯(lián)合主鍵:
alter table test add constraint PK_TEST primary key(ename,birthday);
感謝各位的閱讀!關(guān)于mysql如何將復(fù)合主鍵改為單一主鍵就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
本文名稱:mysql如何將復(fù)合主鍵改為單一主鍵
文章地址:http://aaarwkj.com/article2/gjosic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供面包屑導(dǎo)航、做網(wǎng)站、定制網(wǎng)站、微信小程序、外貿(mào)建站、網(wǎng)站導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)