溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在PostgreSQL中添加各種約束

發(fā)布時(shí)間:2021-02-03 13:27:56 來(lái)源:億速云 閱讀:965 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

如何在PostgreSQL中添加各種約束?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

1. 添加主鍵

alter table goods add primary key(sid);

2. 添加外鍵

alter table orders add foreign key(goods_id) references goods(sid) on update cascade on delete cascade;

on update cascade: 被引用行更新時(shí),引用行自動(dòng)更新;

on update restrict: 被引用的行禁止更新;

on delete cascade: 被引用行刪除時(shí),引用行也一起刪除;

on dellete restrict: 被引用的行禁止刪除;

3. 刪除外鍵

alter table orders drop constraint orders_goods_id_fkey;

4. 添加唯一約束

alter table goods add constraint unique_goods_sid unique(sid);

5. 刪除默認(rèn)值

alter table goods alter column sid drop default;

6. 修改字段的數(shù)據(jù)類型

alter table goods alter column sid type character varying;

7. 重命名字段

alter table goods rename column sid to ssid;

補(bǔ)充:PostgreSQL-主鍵約束和唯一性約束的區(qū)別

在建索引的過(guò)程中遇到一些問(wèn)題,網(wǎng)絡(luò)上搜索了一下基礎(chǔ)知識(shí)。一直以為唯一索引就已經(jīng)是主鍵了,至少在pg中看來(lái)不是這么回事兒。

1)主鍵約束(PRIMARY KEY)

1) 主鍵用于唯一地標(biāo)識(shí)表中的每一條記錄,可以定義一列或多列為主鍵。

2) 是不可能(或很難)更新。

3) 主鍵列上沒(méi)有任何兩行具有相同值(即重復(fù)值),不允許空(NULL)。

4) 主健可作外健,唯一索引不可。

2)唯一性約束(UNIQUE)

1) 唯一性約束用來(lái)限制不受主鍵約束的列上的數(shù)據(jù)的唯一性,用于作為訪問(wèn)某行的可選手段,一個(gè)表上可以放置多個(gè)唯一性約束。

2) 只要唯一就可以更新。

3) 即表中任意兩行在 指定列上都不允許有相同的值,允許空(NULL)。

4) 一個(gè)表上可以放置多個(gè)唯一性約束。

3)唯一索引(INDEX)

創(chuàng)建唯一索引可以確保任何生成重復(fù)鍵值的嘗試都會(huì)失敗。

唯一性約束和主鍵約束的區(qū)別:

(1)唯一性約束允許在該列上存在NULL值,而主鍵約束的限制更為嚴(yán)格,不但不允許有重復(fù),而且也不允許有空值。

(2)在創(chuàng)建唯一性約束和主鍵約束時(shí)可以創(chuàng)建聚集索引和非聚集索引,但在 默認(rèn)情況下主鍵約束產(chǎn)生聚集索引,而唯一性約束產(chǎn)生非聚集索引

約束和索引, 前者是用來(lái)檢查數(shù)據(jù)的正確性,后者用來(lái)實(shí)現(xiàn)數(shù)據(jù)查詢的優(yōu)化,目的不同。

唯一性約束與唯一索引有所不同:

(1)創(chuàng)建唯一約束會(huì)在Oracle中創(chuàng)建一個(gè)Constraint,同時(shí)也會(huì)創(chuàng)建一個(gè)該約束對(duì)應(yīng)的唯一索引。

(2)創(chuàng)建唯一索引只會(huì)創(chuàng)建一個(gè)唯一索引,不會(huì)創(chuàng)建Constraint。

也就是說(shuō)其實(shí)唯一約束是通過(guò)創(chuàng)建唯一索引來(lái)實(shí)現(xiàn)的。

在刪除時(shí)這兩者也有一定的區(qū)別:

刪除唯一約束時(shí)可以只刪除約束而不刪除對(duì)應(yīng)的索引,所以對(duì)應(yīng)的列還是必須唯一的,而刪除了唯一索引的話就可以插入不唯一的值。

關(guān)于如何在PostgreSQL中添加各種約束問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI