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

作者:linux_c_coding_man 时间:2024-01-26 08:48:03 

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', ...

来源:http://blog.csdn.net/peng314899581/article/details/53761097

标签:MySQL,UNIQUE
0
投稿

猜你喜欢

  • python生成tensorflow输入输出的图像格式的方法

    2021-03-20 05:21:08
  • python中numpy基础学习及进行数组和矢量计算

    2023-01-22 16:32:04
  • Anaconda之conda常用命令介绍(安装、更新、删除)

    2021-06-11 22:52:03
  • js实现简单选项卡功能

    2024-04-22 13:05:47
  • Python实现改变与矩形橡胶的线条的颜色代码示例

    2022-08-02 08:16:26
  • oracle 日期函数

    2010-07-23 13:32:00
  • python 实现让字典的value 成为列表

    2022-01-16 00:26:30
  • php字符串截取函数用法分析

    2023-06-28 22:19:26
  • Python split() 函数拆分字符串将字符串转化为列的方法

    2022-02-12 00:14:19
  • MSSQL数据库还原图解教程

    2009-01-12 17:58:00
  • python实现布隆过滤器及原理解析

    2023-03-11 15:01:20
  • MySQL两种表存储结构MyISAM和InnoDB的性能比较测试

    2024-01-28 02:35:55
  • 利用anaconda保证64位和32位的python共存

    2021-07-23 09:18:24
  • pywinauto自动化测试使用经验

    2022-12-21 02:36:10
  • 解决Python列表字符不区分大小写的问题

    2022-09-10 20:43:52
  • MySQL性能优化之路---修改配置文件my.cnf

    2024-01-23 16:20:53
  • python打印异常信息的两种实现方式

    2023-11-17 15:37:41
  • JSP实现用户登录、注册和退出功能

    2024-03-18 10:13:43
  • 详解mysql数据库增删改操作

    2024-01-15 02:23:05
  • MySQL之Explain详解

    2024-01-12 21:14:55
  • asp之家 网络编程 m.aspxhome.com