<bdo id="vljxk"><rt id="vljxk"><noframes id="vljxk"><noframes id="vljxk"><noframes id="vljxk"><rt id="vljxk"></rt><rt id="vljxk"></rt><noframes id="vljxk"><rt id="vljxk"><delect id="vljxk"></delect></rt><noframes id="vljxk"><rt id="vljxk"></rt><noframes id="vljxk"><noframes id="vljxk"><rt id="vljxk"></rt>

當前位置:首頁 >  站長 >  數據庫 >  正文

PostgreSQL 添加各種約束語法的操作

 2021-04-30 16:18  來源: 腳本之家   我來投稿 撤稿糾錯

  阿里云優惠券 先領券再下單

這篇文章主要介紹了PostgreSQL 添加各種約束語法的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

1. 添加主鍵

1alter table goods add primary key(sid);

2. 添加外鍵

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

on update cascade: 被引用行更新時,引用行自動更新;

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

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

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

3. 刪除外鍵

1alter table orders drop constraint orders_goods_id_fkey;

4. 添加唯一約束

1alter table goods add constraint unique_goods_sid unique(sid);

5. 刪除默認值

1alter table goods alter column sid drop default;

6. 修改字段的數據類型

1alter table goods alter column sid type character varying;

7. 重命名字段

1alter table goods rename column sid to ssid;

補充:PostgreSQL-主鍵約束和唯一性約束的區別

在建索引的過程中遇到一些問題,網絡上搜索了一下基礎知識。一直以為唯一索引就已經是主鍵了,至少在pg中看來不是這么回事兒。

1)主鍵約束(PRIMARY KEY)

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

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

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

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

2)唯一性約束(UNIQUE)

1) 唯一性約束用來限制不受主鍵約束的列上的數據的唯一性,用于作為訪問某行的可選手段,一個表上可以放置多個唯一性約束。

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

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

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

3)唯一索引(INDEX)

創建唯一索引可以確保任何生成重復鍵值的嘗試都會失敗。

唯一性約束和主鍵約束的區別:

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

(2)在創建唯一性約束和主鍵約束時可以創建聚集索引和非聚集索引,但在 默認情況下主鍵約束產生聚集索引,而唯一性約束產生非聚集索引

約束和索引, 前者是用來檢查數據的正確性,后者用來實現數據查詢的優化,目的不同。

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

(1)創建唯一約束會在Oracle中創建一個Constraint,同時也會創建一個該約束對應的唯一索引。

(2)創建唯一索引只會創建一個唯一索引,不會創建Constraint。

也就是說其實唯一約束是通過創建唯一索引來實現的。

在刪除時這兩者也有一定的區別:

刪除唯一約束時可以只刪除約束而不刪除對應的索引,所以對應的列還是必須唯一的,而刪除了唯一索引的話就可以插入不唯一的值。

文章來源:腳本之家

來源地址:https://www.jb51.net/article/205216.htm

申請創業報道,分享創業好點子。點擊此處,共同探討創業新機遇!

相關文章

熱門排行

信息推薦