源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

MySQL使用UNIQUE实现数据不重复插入

  • 时间:2021-08-27 21:52 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:MySQL使用UNIQUE实现数据不重复插入
[b]SQL UNIQUE 约束 [/b] UNIQUE 约束唯一标识数据库表中的每条记录。 UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。 PRIMARY KEY 拥有自动定义的 UNIQUE 约束。 请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。 下面的 SQL 在 “Persons” 表创建时在 “Id_P” 列创建 UNIQUE 约束:
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 语法:
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: [code]ALTER TABLE Persons ADD UNIQUE (Id_P)[/code] 如需命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束,请使用下面的 SQL 语法: [code]ALTER TABLE Persons ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName) [/code] 如需撤销 UNIQUE 约束,请使用下面的 SQL: [code]ALTER TABLE Persons DROP INDEX uc_PersonID[/code] 这样每次插入重复记录时MySQL就会提示Duplicate entry value1-value2 for key uni_que,当然你可以在insert的时候加入ignore来忽略掉 现在保证了无重复记录后,我们要开始记录不存在则插入,存在则更新操作 [code]INSERT INTO tablename (field1, field2, field3, ...) VALUES ('value1', 'value2','value3', ...) ON DUPLICATE KEY UPDATE field1='value1', field2='value2', field3='value3', ...[/code] 这个语句的意思是,插入值,如果没有该记录执行 [code]INSERT INTO tablename (field1, field2, field3, ...) VALUES ('value1', 'value2','value3', ...)[/code] 这一段,如果存在该记录,那么执行 [code]UPDATE field1='value1', field2='value2', field3='value3', ...[/code]
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部