MySQL使用UNIQUE实现数据不重复插入
unique列在一个UNIQUE键上插入包含重复值的记录时,我们可以控制MySQL如何处理这种情况:使用IGNORE关键字或者ON DUPLICATE KEY UPDATE子句跳过INSERT、中断操作或者更新旧记录为新值。
SQL UNIQUE 约束
UNIQUE 约束唯一标识数据库表中的每条记录。 UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。 PRIMARY KEY 拥有自动定义的 UNIQUE 约束。
请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。
下面的 SQL 在 “Persons” 表创建时在 “Id_P” 列创建 UNIQUE 约束:
1
2
3
4
5
6
7
8
9
|
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 语法:
1
2
3
4
5
6
7
8
9
|
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', ...
最新文章
- 饿了么基于Vue2.0的通用组件开发之路(分享会记录)
- python-print
- usaco 2016 Feb 负载平衡
- linux上安装jdk并添加环境变量
- System.nanoTime()的使用
- web前端性能意义、关注重点、测试方案、优化技巧
- CodeIgniter的缓存设置
- openssl数字证书常见格式与协议介绍
- Java基础知识强化之集合框架笔记60:Map集合之TreeMap(TreeMap<;Student,String>;)的案例
- bash shell学习-shell基础 (笔记)
- (HLS播放器之中的一个)HLS协议之M3U8解析
- MFC的最大化,最小化,关闭
- u盘安装ubuntu10.04 server.txt
- 条形码/二维码之开源利器ZXing图文介绍(转)
- JavaScript在智能手机上的应用-判断是否为移动浏览器
- 3856: Monster
- PHP 引用是个坑,请慎用
- HBase应用快速开发
- Hbase_02、Hbase的常用的shell命令&;Hbase的DDL操作&;Hbase的DML操作(转)
- Python--subprocess系统命令模块-深入
热门文章
- [Training Video - 4] [Groovy] Constructors in groovy, this keyword
- QT学习之窗口部件
- css3之transform-origin
- 删除emacs临时文件
- A Multi-Sensorial Simultaneous Localization and Mapping (SLAM) System for Low-Cost Micro Aerial Vehicles in GPS-Denied Environments
- jquery插件中(function ( $, window, document, undefined )的作用
- [LintCode笔记了解一下]64.合并排序数组
- zookeeper学习及安装
- VMware下拷过来的Linux系统ifconfig下没有网络问题
- docker 命令大全