欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-03-21 10:29:44
sql unique 约束 unique 约束唯一标识数据库表中的每条记录。 unique 和 primary key 约束均为列或列集合提供了唯一性的保证。...

sql unique 约束

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:

alter table persons add unique (id_p)

如需命名 unique 约束,并定义多个列的 unique 约束,请使用下面的 sql 语法:

alter table persons add constraint uc_personid unique (id_p,lastname)

如需撤销 unique 约束,请使用下面的 sql:

alter table persons drop index uc_personid

这样每次插入重复记录时mysql就会提示duplicate entry value1-value2 for key uni_que,当然你可以在insert的时候加入ignore来忽略掉
现在保证了无重复记录后,我们要开始记录不存在则插入,存在则更新操作

insert into tablename (field1, field2, field3, ...) values ('value1', 'value2','value3', ...) on duplicate key update field1='value1', field2='value2', field3='value3', ...

这个语句的意思是,插入值,如果没有该记录执行

insert into tablename (field1, field2, field3, ...) values ('value1', 'value2','value3', ...)

这一段,如果存在该记录,那么执行

update field1='value1', field2='value2', field3='value3', ...