《MYSQL數據庫MySQL使用UNIQUE實現數據不重復插入》要點:
本文介紹了MYSQL數據庫MySQL使用UNIQUE實現數據不重復插入,希望對您有用。如果有疑問,可以聯系我們。
SQL UNIQUE 約束
MYSQL必讀
UNIQUE 約束唯一標識數據庫表中的每條記錄.
UNIQUE 和 PRIMARY KEY 約束均為列或列集合提供了唯一性的保證.
PRIMARY KEY 擁有自動定義的 UNIQUE 約束.
MYSQL必讀
請注意,每個表可以有多個 UNIQUE 約束,但是每個表只能有一個 PRIMARY KEY 約束.
MYSQL必讀
下面的 SQL 在 “Persons” 表創建時在 “Id_P” 列創建 UNIQUE 約束:MYSQL必讀
CREATE TABLE Persons ( Id_P int NOT NULL, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255), UNIQUE (Id_P) )
如果需要命名 UNIQUE 約束,以及為多個列定義 UNIQUE 約束,請使用下面的 SQL 語法:MYSQL必讀
CREATE TABLE Persons ( Id_P int NOT NULL, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255), CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName) )
當表已被創建時,如需在 “Id_P” 列創建 UNIQUE 約束,請使用下列 SQL:MYSQL必讀
ALTER TABLE Persons ADD UNIQUE (Id_P)
MYSQL必讀
如需命名 UNIQUE 約束,并定義多個列的 UNIQUE 約束,請使用下面的 SQL 語法:MYSQL必讀
ALTER TABLE Persons ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)
MYSQL必讀
如需撤銷 UNIQUE 約束,請使用下面的 SQL:MYSQL必讀
ALTER TABLE Persons DROP INDEX uc_PersonID
MYSQL必讀
這樣每次插入重復記錄時MySQL就會提示Duplicate entry value1-value2 for key uni_que,當然你可以在insert的時候加入ignore來忽略掉
現在保證了無重復記錄后,我們要開始記錄不存在則插入,存在則更新操作MYSQL必讀
INSERT INTO tablename (field1, field2, field3, ...) VALUES ('value1', 'value2','value3', ...) ON DUPLICATE KEY UPDATE field1='value1', field2='value2', field3='value3', ...
MYSQL必讀
這個語句的意思是,插入值,如果沒有該記錄執行MYSQL必讀
INSERT INTO tablename (field1, field2, field3, ...) VALUES ('value1', 'value2','value3', ...)
MYSQL必讀
這一段,如果存在該記錄,那么執行
MYSQL必讀
UPDATE field1='value1', field2='value2', field3='value3', ...
MYSQL必讀
《MYSQL數據庫MySQL使用UNIQUE實現數據不重復插入》是否對您有啟發,歡迎查看更多與《MYSQL數據庫MySQL使用UNIQUE實現數據不重復插入》相關教程,學精學透。維易PHP學院為您提供精彩教程。