欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL?FOREIGN?KEY約束保障表之間關系完整性關鍵規(guī)則詳解

 更新時間:2023年12月10日 10:53:38   作者:小萬哥  
這篇文章主要介紹了SQL?FOREIGN?KEY約束保障表之間關系完整性關鍵規(guī)則詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

SQL FOREIGN KEY 約束

SQL FOREIGN KEY 約束用于防止破壞表之間關系的操作。FOREIGN KEY 是一張表中的字段(或字段集合),它引用另一張表中的主鍵。具有外鍵的表稱為子表,具有主鍵的表稱為被引用表或父表。

以下是兩個表的例子:

Persons 表

PersonID  LastName  FirstName  Age
1          Hansen      Ola          30
2          Svendson  Tove      23
3          Pettersen  Kari      20

Orders 表

OrderID  OrderNumber  PersonID
1      77895      3
2      44678      3
3      22456      2
4      24562      1

注意,"Orders" 表中的 "PersonID" 列指向 "Persons" 表中的 "PersonID" 列。"Persons" 表中的 "PersonID" 列是 "Persons" 表中的主鍵。"Orders" 表中的 "PersonID" 列是 "Orders" 表中的外鍵。

FOREIGN KEY 約束防止將無效數(shù)據(jù)插入到外鍵列中,因為它必須是父表中包含的值之一。

在 CREATE TABLE 時使用 SQL FOREIGN KEY

以下 SQL 在創(chuàng)建 "Orders" 表時在 "PersonID" 列上創(chuàng)建了一個 FOREIGN KEY

對于 MySQL:

CREATE TABLE Orders (
    OrderID int NOT NULL,
    OrderNumber int NOT NULL,
    PersonID int,
    PRIMARY KEY (OrderID),
    FOREIGN KEY (PersonID) REFERENCES Persons(PersonID)
);

對于 SQL Server / Oracle / MS Access:

CREATE TABLE Orders (
    OrderID int NOT NULL PRIMARY KEY,
    OrderNumber int NOT NULL,
    PersonID int FOREIGN KEY REFERENCES Persons(PersonID)
);

要允許對 FOREIGN KEY 約束進行命名,并在多列上定義 FOREIGN KEY 約束,請使用以下 SQL 語法:

對于 MySQL / SQL Server / Oracle / MS Access:

CREATE TABLE Orders (
    OrderID int NOT NULL,
    OrderNumber int NOT NULL,
    PersonID int,
    PRIMARY KEY (OrderID),
    CONSTRAINT FK_PersonOrder FOREIGN KEY (PersonID)
    REFERENCES Persons(PersonID)
);

在 ALTER TABLE 時使用 SQL FOREIGN KEY

要在表已經(jīng)創(chuàng)建的情況下在 "PersonID" 列上創(chuàng)建 FOREIGN KEY 約束,請使用以下 SQL:

對于 MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Orders
ADD FOREIGN KEY (PersonID) REFERENCES Persons(PersonID);

要允許對 FOREIGN KEY 約束進行命名,并在多列上定義 FOREIGN KEY 約束,請使用以下 SQL 語法:

對于 MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Orders
ADD CONSTRAINT FK_PersonOrder
FOREIGN KEY (PersonID) REFERENCES Persons(PersonID);

刪除 FOREIGN KEY 約束

要刪除 FOREIGN KEY 約束,請使用以下 SQL:

對于 MySQL:

ALTER TABLE Orders
DROP FOREIGN KEY FK_PersonOrder;

對于 SQL Server / Oracle / MS Access:

ALTER TABLE Orders
DROP CONSTRAINT FK_PersonOrder;

通過這些 SQL 語句,您可以在數(shù)據(jù)庫中定義和管理 FOREIGN KEY 約束,以確保表之間的關系得到維護。

SQL CHECK 約束

SQL CHECK 約束用于限制可以放入列中的值范圍。如果在列上定義了 CHECK 約束,它將僅允許為該列指定某些值。如果在表上定義了 CHECK 約束,它可以基于行中其他列的值來限制某些列中的值。

在 CREATE TABLE 時使用 SQL CHECK

以下 SQL 在創(chuàng)建 "Persons" 表時在 "Age" 列上創(chuàng)建了一個 CHECK 約束。CHECK 約束確保一個人的年齡必須是 18 歲或以上:

對于 MySQL:

CREATE TABLE Persons (
    ID int NOT NULL,
    LastName varchar(255) NOT NULL,
    FirstName varchar(255),
    Age int,
    CHECK (Age>=18)
);

對于 SQL Server / Oracle / MS Access:

CREATE TABLE Persons (
    ID int NOT NULL,
    LastName varchar(255) NOT NULL,
    FirstName varchar(255),
    Age int CHECK (Age>=18)
);

要允許對 CHECK 約束進行命名,并在多列上定義 CHECK 約束,請使用以下 SQL 語法:

對于 MySQL / SQL Server / Oracle / MS Access:

CREATE TABLE Persons (
    ID int NOT NULL,
    LastName varchar(255) NOT NULL,
    FirstName varchar(255),
    Age int,
    City varchar(255),
    CONSTRAINT CHK_Person CHECK (Age>=18 AND City='Sandnes')
);

在 ALTER TABLE 時使用 SQL CHECK

要在表已經(jīng)創(chuàng)建的情況下在 "Age" 列上創(chuàng)建 CHECK 約束,請使用以下 SQL:

對于 MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ADD CHECK (Age>=18);

要允許對 CHECK 約束進行命名,并在多列上定義 CHECK 約束,請使用以下 SQL 語法:

對于 MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ADD CONSTRAINT CHK_PersonAge CHECK (Age>=18 AND City='Sandnes');

刪除 CHECK 約束

要刪除 CHECK 約束,請使用以下 SQL:

對于 SQL Server / Oracle / MS Access:

ALTER TABLE Persons
DROP CONSTRAINT CHK_PersonAge;

對于 MySQL:

ALTER TABLE Persons
DROP CHECK CHK_PersonAge;

通過這些 SQL 語句,您可以在數(shù)據(jù)庫中定義和管理 CHECK 約束,以確保列中的值滿足指定的條件。

SQL DEFAULT 約束

SQL DEFAULT 約束用于為列設置默認值。如果沒有指定其他值,將在所有新記錄中添加默認值。

在 CREATE TABLE 時使用 SQL DEFAULT

以下 SQL 在創(chuàng)建 "Persons" 表時為 "City" 列設置了 DEFAULT 值:

對于 MySQL / SQL Server / Oracle / MS Access:

CREATE TABLE Persons (
    ID int NOT NULL,
    LastName varchar(255) NOT NULL,
    FirstName varchar(255),
    Age int,
    City varchar(255) DEFAULT 'Sandnes'
);

DEFAULT 約束還可以用于通過使用諸如 GETDATE() 之類的函數(shù)插入系統(tǒng)值:

CREATE TABLE Orders (
    ID int NOT NULL,
    OrderNumber int NOT NULL,
    OrderDate date DEFAULT GETDATE()
);

在 ALTER TABLE 時使用 SQL DEFAULT

要在表已經(jīng)創(chuàng)建的情況下在 "City" 列上創(chuàng)建 DEFAULT 約束,請使用以下 SQL:

對于 MySQL:

ALTER TABLE Persons
ALTER City SET DEFAULT 'Sandnes';

對于 SQL Server:

ALTER TABLE Persons
ADD CONSTRAINT df_City
DEFAULT 'Sandnes' FOR City;

對于 MS Access:

ALTER TABLE Persons
ALTER COLUMN City SET DEFAULT 'Sandnes';

對于 Oracle:

ALTER TABLE Persons
MODIFY City DEFAULT 'Sandnes';

刪除 DEFAULT 約束

要刪除 DEFAULT 約束,請使用以下 SQL:

對于 MySQL:

ALTER TABLE Persons
ALTER City DROP DEFAULT;

對于 SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ALTER COLUMN City DROP DEFAULT;

對于 SQL Server:

ALTER TABLE Persons
ALTER COLUMN City DROP DEFAULT;

通過這些 SQL 語句,您可以在數(shù)據(jù)庫中為列設置默認值,確保在插入新記錄時,如果未提供值,將使用指定的默認值。

以上就是SQL FOREIGN KEY約束保障表之間關系完整性關鍵規(guī)則詳解的詳細內(nèi)容,更多關于SQL FOREIGN KEY約束表完整性的資料請關注腳本之家其它相關文章!

相關文章

  • Win7下安裝MySQL5.7.16過程記錄

    Win7下安裝MySQL5.7.16過程記錄

    這篇文章主要為大家分享了Win7下安裝MySQL5.7.16過程的筆記,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • mysql單字段多值分割和合并的處理方法

    mysql單字段多值分割和合并的處理方法

    這篇文章主要給大家介紹了關于mysql單字段多值分割和合并的處理方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • mysql中url時區(qū)的陷阱該如何規(guī)避詳解

    mysql中url時區(qū)的陷阱該如何規(guī)避詳解

    最近在工作中發(fā)現(xiàn)一個問題,是關于mysql中url時區(qū)的,發(fā)現(xiàn)這個陷阱如果大家不注意可能都會遇到,所以給大家總結下,這篇文章主要給大家介紹了關于mysql中url時區(qū)的陷阱該如何規(guī)避的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-08-08
  • MySQL事務及Spring隔離級別實現(xiàn)原理詳解

    MySQL事務及Spring隔離級別實現(xiàn)原理詳解

    這篇文章主要介紹了MySQL事務及Spring隔離級別實現(xiàn)原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • MYSQL 修改root密碼命令小結

    MYSQL 修改root密碼命令小結

    MYSQL 修改root密碼命令小結,需要的朋友可以參考下。
    2011-10-10
  • mysql和oracle默認排序的方法 - 不指定order by

    mysql和oracle默認排序的方法 - 不指定order by

    這篇文章主要介紹了mysql和oracle默認排序的方法 - 不指定order by。具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 詳細深入聊一聊Mysql中的int(1)和int(11)

    詳細深入聊一聊Mysql中的int(1)和int(11)

    mysql數(shù)據(jù)庫作為當前常用的關系型數(shù)據(jù)庫,肯定會遇到設計表的需求,下面對設計表時int類型的設置進行分析,下面這篇文章主要給大家介紹了關于Mysql中int(1)和int(11)的相關資料,需要的朋友可以參考下
    2022-08-08
  • 詳解MySQL 聯(lián)合查詢優(yōu)化機制

    詳解MySQL 聯(lián)合查詢優(yōu)化機制

    MySQL 使用聯(lián)合的形式的地方會遠遠超過我們過去認知的范疇?;旧?,它會認為每個查詢都有聯(lián)合,而不僅僅是從兩張表中查出匹配的數(shù)據(jù)行,這包括了子查詢,甚至僅僅對單表的 SELECT 操作。因此,理解 MySQL 如何執(zhí)行聯(lián)合十分重要。
    2021-05-05
  • MySQL數(shù)據(jù)庫存入Date時天數(shù)會少一天的問題及解決

    MySQL數(shù)據(jù)庫存入Date時天數(shù)會少一天的問題及解決

    這篇文章主要介紹了MySQL數(shù)據(jù)庫存入Date時天數(shù)會少一天的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • MySQL和Oracle批量插入SQL的通用寫法示例

    MySQL和Oracle批量插入SQL的通用寫法示例

    當我們要往數(shù)據(jù)庫中批量保存多條數(shù)據(jù)得時候,分不同數(shù)據(jù)庫,有不同得插入方式,這篇文章主要給大家介紹了關于MySQL和Oracle批量插入SQL的通用寫法的相關資料,需要的朋友可以參考下
    2021-11-11

最新評論