ON DUPLICATE KEY UPDATE注意事项


MySQL 自4.1版以后开始支持INSERT … ON DUPLICATE KEY UPDATE语法,使得原本需要执行3条SQL语句(SELECT,INSERT,UPDATE),缩减为1条语句即可完成。

例如ipstats表结构如下:

引用

CREATE TABLE ipstats (
ip VARCHAR(15) NOT NULL UNIQUE,
clicks SMALLINT(5) UNSIGNED NOT NULL DEFAULT '0'
);

原本需要执行3条SQL语句,如下:

IF (SELECT * FROM ipstats WHERE ip='192.168.0.1') {
 UPDATE ipstats SET clicks=clicks+1 WHERE ip='192.168.0.1';
} else {
 INSERT INTO ipstats (ip, clicks) VALUES ('192.168.0.1', 1);
}

而现在只需下面1条SQL语句即可完成:

INSERT INTO ipstats VALUES('192.168.0.1', 1) ON DUPLICATE KEY UPDATE clicks=clicks+1;

注意,要使用这条语句,前提条件是这个表必须有一个唯一索引或主键。



相关阅读:
W3 Jmail 简要介绍
DeDecms SEO优化经验谈(适用于任何网站)
无限分类与树型论坛的实现方法
IE 选择符的4095限制
IE6盒子模型没问题 详测双倍边距
解决MySQL中文输出变成问号的问题
JavaScript 利用StringBuffer类提升+=拼接字符串效率
用 Ajax和 RSS制作一个首页新闻(1)
使用批处理文件异地备份数据库(最近几天的数据)
CCPry JS类库 代码
Redhat9+Apache+Mysql+PHP+GD2+Perl安装教程
Oracle数据库SQLPLUS中几个常用set语句
细品javascript 寻址,闭包,对象模型和相关问题
mssql查找备注(text,ntext)类型字段为空的方法
快速导航

Copyright © 2016 phpStudy |