簡體   English   中英

使每個外鍵的mySQL列唯一

[英]Make mySQL column unique for each foreign key

假設我的數據庫中有以下列:

Item:
id int PRIMARY KEY,
name string,
foreign_id FOREIGN KEY

有沒有一種方法可以在每次插入之前不查詢數據庫,即一個外鍵不能包含兩個具有相同名稱的行?

當然,您想為外鍵列添加一個(唯一的)索引。 要添加的SQL命令是

ALTER TABLE `mytable`
ADD UNIQUE INDEX `mytable_idx__1` (`foreign_id`);

如果我理解正確,則可能要使用UNIQUE約束:

CREATE TABLE (
    id          INT PRIMARY KEY
  , name        VARCHAR(50) --or whatever you need
  , foreign_id  INT UNIQUE
    FOREIGN KEY (foreign_id) REFERENCES...
);

當我了解使用FOREIGN KEY(foreign_id)參考時,---將解決它。 並確保始終將表的unique key作為其他表的foreign key

CREATE TABLE profile
( 
  id int NOT NULL PRIMARY KEY,
  name varchar(50),
  FOREIGN KEY (name)
     REFERENCES member (name) 
     ON DELETE CASCADE
     ON UPDATE CASCADE
) ENGINE=InnoDB ;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM