欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

mysql如何將復合主鍵改為單一主鍵

這篇文章給大家分享的是有關MySQL如何將復合主鍵改為單一主鍵的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)基于分布式IDC數(shù)據(jù)中心構建的平臺為眾多戶提供電信內(nèi)江機房 四川大帶寬租用 成都機柜租用 成都服務器租用。

所謂的復合主鍵 就是指你表的主鍵含有一個以上的字段組成,不使用無業(yè)務含義的自增id作為主鍵。

比如

create table test 
( 
   name varchar(19), 
   id number, 
   value varchar(10), 
   primary key (name,id) 
)

上面的name和id字段組合起來就是你test表的復合主鍵 ,它的出現(xiàn)是因為你的name字段可能會出現(xiàn)重名,所以要加上ID字段這樣就可以保證你記錄的唯一性 ,一般情況下,主鍵的字段長度和字段數(shù)目要越少越好 。

mysql如何將復合主鍵改為單一主鍵

這里就會有一個疑惑?  主鍵是唯一的索引,那么為何一個表可以創(chuàng)建多個主鍵呢?

其實“主鍵是唯一的索引”這話有點歧義的。舉個例子,我們在表中創(chuàng)建了一個ID字段,自動增長,并設為主鍵,這個是沒有問題的,因為“主鍵是唯一的索引”,ID自動增長保證了唯一性,所以可以。

此時,我們再創(chuàng)建一個字段name,類型為varchar,也設置為主鍵,你會發(fā)現(xiàn),在表的多行中你是可以填寫相同的name值的,這豈不是有違“主鍵是唯一的索引”這句話么?

所以我才說“主鍵是唯一的索引”是有歧義的。應該是“當表中只有一個主鍵時,它是唯一的索引;當表中有多個主鍵時,稱為復合主鍵,復合主鍵聯(lián)合保證唯一索引”。

為什么自增長ID已經(jīng)可以作為唯一標識的主鍵,為啥還需要復合主鍵呢。因為,并不是所有的表都要有ID這個字段,比如,我們建一個學生表,沒有唯一能標識學生的ID,怎么辦呢,學生的名字、年齡、班級都可能重復,無法使用單個字段來唯一標識,這時,我們可以將多個字段設置為主鍵,形成復合主鍵,這多個字段聯(lián)合標識唯一性,其中,某幾個主鍵字段值出現(xiàn)重復是沒有問題的,只要不是有多條記錄的所有主鍵值完全一樣,就不算重復。

怎么把復合主鍵改為單一主鍵

一個表只能有一個主鍵:

基于一列的主鍵:

alter table test add constraint PK_TEST primary key(ename);

基于多列的聯(lián)合主鍵:

alter table test add constraint PK_TEST primary key(ename,birthday);

感謝各位的閱讀!關于mysql如何將復合主鍵改為單一主鍵就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

本文名稱:mysql如何將復合主鍵改為單一主鍵
文章地址:http://chinadenli.net/article2/gjosic.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供面包屑導航做網(wǎng)站定制網(wǎng)站微信小程序外貿(mào)建站網(wǎng)站導航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設網(wǎng)站維護公司