设为首页 收藏本站
查看: 867|回复: 0

[经验分享] mysql的replace into和on duplicate key update测试笔记

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-5-27 08:42:48 | 显示全部楼层 |阅读模式
mysql的replace into和on duplicate key update测试笔记

mysql> create table tbl_insert_tmp(id int(5),addr_number int(10), name varchar(20),primary key (id),unique key udx_addr_number (addr_number));      
Query OK, 0 rows affected (0.05 sec)

mysql> show create table tbl_insert_tmp\G
*************************** 1. row ***************************
       Table: tbl_insert_tmp
Create Table: CREATE TABLE `tbl_insert_tmp` (
  `id` int(5) NOT NULL DEFAULT '0',
  `addr_number` int(10) DEFAULT NULL,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `udx_addr_number` (`addr_number`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

mysql>


1、测试on duplicate key update(是根据主键或唯一键如果有对应键则更新,没有对应键就插入,所以使用起来不会删除正常数据)


mysql> insert into tbl_insert_tmp values(1,100,'a'),(2,200,'b'),(3,300,'c');
Query OK, 3 rows affected (0.01 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> select * from tbl_insert_tmp ;
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         100 | a    |
|  2 |         200 | b    |
|  3 |         300 | c    |
+----+-------------+------+
3 rows in set (0.00 sec)

mysql>

主键id和addr_number唯一键没有重复,直接插入
mysql> insert into tbl_insert_tmp(id,addr_number,name) values(4,400,'d') on duplicate key update name='haha';
Query OK, 1 row affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         100 | a    |
|  2 |         200 | b    |
|  3 |         300 | c    |
|  4 |         400 | d    |
+----+-------------+------+
4 rows in set (0.00 sec)

mysql>



因为id是主键有重复1直接更新

mysql> insert into tbl_insert_tmp(id,addr_number,name) values(1,500,'d') on duplicate key update name='haha';     
Query OK, 2 rows affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         100 | haha |
|  2 |         200 | b    |
|  3 |         300 | c    |
|  4 |         400 | d    |
+----+-------------+------+
4 rows in set (0.00 sec)



因为addr_number唯一键有重复400直接更新

mysql> insert into tbl_insert_tmp(id,addr_number,name) values(5,400,'d') on duplicate key update name='hehe';      
Query OK, 2 rows affected (0.03 sec)

mysql> select * from tbl_insert_tmp ;
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         100 | haha |
|  2 |         200 | b    |
|  3 |         300 | c    |
|  4 |         400 | hehe |
+----+-------------+------+
4 rows in set (0.00 sec)

mysql>


删除addr_number唯一键就可以直接插入重复值
mysql> alter table tbl_insert_tmp drop key udx_addr_number;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> show create table  tbl_insert_tmp\G
*************************** 1. row ***************************
       Table: tbl_insert_tmp
Create Table: CREATE TABLE `tbl_insert_tmp` (
  `id` int(5) NOT NULL DEFAULT '0',
  `addr_number` int(10) DEFAULT NULL,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

mysql>
mysql> insert into tbl_insert_tmp(id,addr_number,name) values(5,400,'d') on duplicate key update name='hehe';
Query OK, 1 row affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;                                                                        
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         100 | haha |
|  2 |         200 | b    |
|  3 |         300 | c    |
|  4 |         400 | hehe |
|  5 |         400 | d    |
+----+-------------+------+
5 rows in set (0.00 sec)

mysql>


2、测试replace into (是根据主键或者唯一键先删除对应键值再插入,所以会删除正常数据,使用时要特别小心)


mysql> truncate table tbl_insert_tmp;
Query OK, 0 rows affected (0.03 sec)

mysql> show create table tbl_insert_tmp\G
*************************** 1. row ***************************
       Table: tbl_insert_tmp
Create Table: CREATE TABLE `tbl_insert_tmp` (
  `id` int(5) NOT NULL DEFAULT '0',
  `addr_number` int(10) DEFAULT NULL,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

mysql> alter table tbl_insert_tmp add unique key udx_addr_number(addr_number);
Query OK, 0 rows affected (0.08 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> show create table tbl_insert_tmp\G                                    
*************************** 1. row ***************************
       Table: tbl_insert_tmp
Create Table: CREATE TABLE `tbl_insert_tmp` (
  `id` int(5) NOT NULL DEFAULT '0',
  `addr_number` int(10) DEFAULT NULL,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `udx_addr_number` (`addr_number`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

mysql>
mysql>
mysql> insert into tbl_insert_tmp values(1,100,'a'),(2,200,'b'),(3,300,'c'),(4,400,'d');
Query OK, 4 rows affected (0.00 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> select * from tbl_insert_tmp ;                                                   
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         100 | a    |
|  2 |         200 | b    |
|  3 |         300 | c    |
|  4 |         400 | d    |
+----+-------------+------+
4 rows in set (0.00 sec)

mysql>




mysql> replace into tbl_insert_tmp values(1,500,'e');                                   
Query OK, 2 rows affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;               
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         500 | e    |
|  2 |         200 | b    |
|  3 |         300 | c    |
|  4 |         400 | d    |
+----+-------------+------+
4 rows in set (0.00 sec)

mysql>
mysql> replace into tbl_insert_tmp values(2,500,'f');
Query OK, 3 rows affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;               
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  2 |         500 | f    |
|  3 |         300 | c    |
|  4 |         400 | d    |
+----+-------------+------+
3 rows in set (0.00 sec)

mysql>

mysql> replace into tbl_insert_tmp values(5,500,'h');
Query OK, 2 rows affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;               
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  3 |         300 | c    |
|  4 |         400 | d    |
|  5 |         500 | h    |
+----+-------------+------+
3 rows in set (0.00 sec)

mysql>


删除唯一键udx_addr_number

mysql> alter table tbl_insert_tmp drop key udx_addr_number;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql>
mysql> replace into tbl_insert_tmp values(1,500,'g');     
Query OK, 1 row affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;                     
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         500 | g    |
|  3 |         300 | c    |
|  4 |         400 | d    |
|  5 |         500 | h    |
+----+-------------+------+
4 rows in set (0.00 sec)

mysql>
mysql> replace into tbl_insert_tmp values(2,300,'i');
Query OK, 1 row affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;               
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         500 | g    |
|  2 |         300 | i    |
|  3 |         300 | c    |
|  4 |         400 | d    |
|  5 |         500 | h    |
+----+-------------+------+
5 rows in set (0.00 sec)

mysql> replace into tbl_insert_tmp values(2,200,'b');
Query OK, 2 rows affected (0.00 sec)

mysql> select * from tbl_insert_tmp ;               
+----+-------------+------+
| id | addr_number | name |
+----+-------------+------+
|  1 |         500 | g    |
|  2 |         200 | b    |
|  3 |         300 | c    |
|  4 |         400 | d    |
|  5 |         500 | h    |
+----+-------------+------+
5 rows in set (0.00 sec)

mysql>

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-71018-1-1.html 上篇帖子: 基于mysql-5.5.32的单机多实例多配置文件的 下篇帖子: 教你如何处理忘记mysql服务器密码的办法 replace update mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表