MySQL是一種關系型數據庫管理系統,它支持約束(Constraint)。在數據庫中,約束是用于限制插入、修改或刪除表中數據的規則。MySQL約束是基于表中數據之間的關系而定義的。MySQL支持以下約束類型:
PRIMARY KEY:定義一個字段或一組字段作為主鍵,它可以作為表中每個記錄的唯一標識符。每個表只能有一個主鍵,且主鍵值不能為NULL。 UNIQUE:可以用來限制字段的唯一性,確保表中某個字段的值不會重復出現。每個表可以定義多個UNIQUE字段,但是值不能為NULL。 FOREIGN KEY:定義一個指向另一個表的關聯字段。它可以用來創建表之間的關聯關系。在一個表中,FOREIGN KEY字段的值必須在另一個表中的主鍵或唯一鍵中存在。 CHECK:用于定義一個表中某個字段所允許的值域。CHECK約束可以限制某個字段的取值范圍,確保它只接受特定的數據類型或值。
以下是一個示例表,其中包含了各種約束:
CREATE TABLE orders ( order_id INT PRIMARY KEY NOT NULL, customer_id INT NOT NULL, order_date DATE NOT NULL, amount DECIMAL(8,2) NOT NULL, CONSTRAINT uc_orders UNIQUE (customer_id, order_date), CONSTRAINT fk_orders_customer FOREIGN KEY (customer_id) REFERENCES customers(customer_id), CONSTRAINT ck_orders_amount CHECK (amount >0) );
這個表中定義了一個名為orders的表,包含4個字段和3個約束。其中,order_id被定義為主鍵,確保每個記錄都具有唯一的標識符。customer_id用于與另一個表關聯,它被定義為FOREIGN KEY,確保每個記錄都有一個有效的客戶ID。order_date和amount字段不能為NULL,且同時指定了一些額外的約束。uc_orders聯合了customer_id和order_date字段創建了一個唯一約束,確保每個客戶在相同日期只能下一次訂單。fk_orders_customer用于定義FOREIGN KEY關系,確保每個訂單都是由現有的客戶下的。ck_orders_amount定義了一個CHECK約束,確保訂單金額大于零。