当前位置: 首页 > 图文教程 > 数据库 > MYSQL > mysql 记录不存在时插入 记录存在则更新的实现方法

MYSQL
ext3下删除mysql数据库的数据恢复案例
mysql性能的检查和调优方法
数据库查询的分页优化技巧
如何才能有效对抗MySQL数据库的解密高手
mysql中从字段中URL提取域名信息
教你四种方法用来查看mysql版本
MySQL数据库数据备份和恢复详解
ubuntu下简单配置mysql数据库
MySQL数据库的root口令恢复方法总结
再谈 MySQL 数据库备份恢复和乱码问题
修改 Navicat 默认备份路径
MySQL数据库中修改密码及访问限制设置详解
小白讲座:在win下mysql备份恢复命令概括
菜鸟大讲堂:如何查看mysql版本的四种方法
扫盲大讲堂:mysql出错的代码解析及解答
MySQL安全大讲堂:MySQL数据库安全配置
怎样在vc、delphi中使用mysql(mysql odbc驱动的使用)
MySQL数据导入与导出之二
如何实现MySQL中的用户管理?
win 2000 安装 mysql-shareware-3.22.32-win

MYSQL 中的 mysql 记录不存在时插入 记录存在则更新的实现方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 74 ::
收藏到网摘: n/a

相信很多人都需要用到这个语句,请看下文:(在4.1以后的版本才有效)
复制代码 代码如下:

mysql> truncate `200702`;
Query OK, 0 rows affected (0.01 sec)
mysql> select * from `200702`;
Empty set (0.01 sec)<span id="more-22"></span>
mysql> insert into `200702` (`domain`, `2nd_domain`, `tld`, `query_ns1`, `query_ns2`, `report_date`) values ('dnspod.com', 'dnspod', 'com', 1000, 2000, '2007-02-04') ON DUPLICATE KEY UPDATE `query_ns1` = `query_ns1` + 1000, `query_ns2` = `query_ns2` + 2000;
Query OK, 1 row affected (0.00 sec)
mysql> select * from `200702`;
+----+------------+------------+------+-----------+-----------+-----------+-----------+-------------+
| id | domain | 2nd_domain | tld | query_ns1 | query_ns2 | query_ns3 | query_ns4 | report_date |
+----+------------+------------+------+-----------+-----------+-----------+-----------+-------------+
| 1 | dnspod.com | dnspod | com | 1000 | 2000 | 0 | 0 | 2007-02-04 |
+----+------------+------------+------+-----------+-----------+-----------+-----------+-------------+
1 row in set (0.00 sec)
mysql> insert into `200702` (`domain`, `2nd_domain`, `tld`, `query_ns1`, `query_ns2`, `report_date`) values ('dnspod.com', 'dnspod', 'com', 1000, 2000, '2007-02-04') ON DUPLICATE KEY UPDATE `query_ns1` = `query_ns1` + 1000, `query_ns2` = `query_ns2` + 2000;
Query OK, 2 rows affected (0.01 sec)
mysql> select * from `200702`;
+----+------------+------------+------+-----------+-----------+-----------+-----------+-------------+
| id | domain | 2nd_domain | tld | query_ns1 | query_ns2 | query_ns3 | query_ns4 | report_date |
+----+------------+------------+------+-----------+-----------+-----------+-----------+-------------+
| 1 | dnspod.com | dnspod | com | 2000 | 4000 | 0 | 0 | 2007-02-04 |
+----+------------+------------+------+-----------+-----------+-----------+-----------+-------------+
1 row in set (0.01 sec)
mysql>
当然,建表的时候,千万别忘记了给domain做一个unique
UNIQUE KEY `domain` (`domain`,`report_date`)