【MySQL】replace into 淺析之一
一 介紹
在筆者支援業務過程中,經常遇到開發諮詢replace into 的使用場景以及注意事項,這裡做個總結。從功能原理,效能和注意事項上做個說明。
二 原理
2.1 當表中存在主鍵但是不存在唯一建的時候。
表結構
如果本來已經存在的主鍵值,那麼MySQL做update操作。
如果本來相應的主鍵值沒有,那麼做insert 操作 replace into yy values(2,'bbb');
2.2 當表中主鍵和唯一鍵同時存在時
情形1 主鍵衝突
主鍵衝突時,資料庫對錶做先刪除然後插入的操作,也即先刪除id=1的記錄,然後插入新的id=1 的記錄(1,2,5).
情形2 唯一建衝突
主鍵不衝突,唯一鍵衝突時,資料庫對錶 唯一鍵為(3,6)的行做update操作,將主鍵修改為要插入的值,id=4 改為id=5。
情形3 主鍵和唯一鍵同時衝突,如果需要插入的值的主鍵 和唯一和表中已經存在的存在衝突。
要插入的值(1,3,6) 主鍵於 表裡面的id=1的值衝突,唯一鍵(3,6)和表中id=5的記錄衝突,MySQL 處理的時候 ,先刪除id=1的行,然後更新了id=5的行。
三 結論
對錶進行replace into操作的時候,
當不存在衝突時,replace into 相當於insert操作。
當存在pk衝突的時候是先delete再insert,如果主鍵是自增的,則自增主鍵會做 +1 操作。【5.5,5.6版本均做過測試】
當存在uk衝突的時候是直接update。,如果主鍵是自增的,則自增主鍵會做 +1 操作。 【5.5,5.6版本均做過測試】
瞭解上述原理和結論之後,以後再遇到replace into 的時候,相信各位讀者可以知道如何選擇,由於篇幅限制,後續文章會基於replace into原理,講述生產過程中的注意事項。
在筆者支援業務過程中,經常遇到開發諮詢replace into 的使用場景以及注意事項,這裡做個總結。從功能原理,效能和注意事項上做個說明。
二 原理
2.1 當表中存在主鍵但是不存在唯一建的時候。
表結構
-
CREATE TABLE `yy` (
-
`id` bigint(20) NOT NULL,
-
`name` varchar(20) DEFAULT NULL,
-
PRIMARY KEY (`id`)
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-
root@test 02:43:58>insert into yy values(1,'abc');
-
Query OK, 1 row affected (0.00 sec)
-
root@test 02:44:25>replace into yy values(2,'bbb');
-
Query OK, 1 row affected (0.00 sec)
-
root@test 02:55:42>select * from yy;
-
+----+------+
-
| id | name |
-
+----+------+
-
| 1 | abc |
-
| 2 | bbb |
-
+----+------+
-
2 rows in set (0.00 sec)
-
root@test 02:55:56>replace into yy values(1,'ccc');
- Query OK, 2 rows affected (0.00 sec)
-
### UPDATE test.yy
-
### WHERE
-
### @1=1 /* LONGINT meta=0 nullable=0 is_null=0 */
-
### @2='abc' /* VARSTRING(60) meta=60 nullable=1 is_null=0 */
-
### SET
-
### @1=1 /* LONGINT meta=0 nullable=0 is_null=0 */
- ### @2='ccc' /* VARSTRING(60) meta=60 nullable=1 is_null=0 */
-
### INSERT INTO test.yy
-
### SET
-
### @1=2 /* LONGINT meta=0 nullable=0 is_null=0 */
-
### @2='bbb' /* VARSTRING(60) meta=60 nullable=1 is_null=0 */
-
# at 623
- #140314 2:55:42 server id 136403306 end_log_pos 650 Xid = 6090885569
-
CREATE TABLE `yy` (
-
`id` int(11) NOT NULL DEFAULT \'0\',
-
`b` int(11) DEFAULT NULL,
-
`c` int(11) DEFAULT NULL
-
PRIMARY KEY (`a`),
-
UNIQUE KEY `uk_bc` (`b`,`c`)
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8
-
root@test 04:37:18>replace into yy values(1,2,3);
-
Query OK, 1 row affected (0.00 sec)
-
root@test 04:37:37>replace into yy values(2,2,4);
-
Query OK, 1 row affected (0.00 sec)
-
root@test 04:38:05>select * from yy;
-
+----+------+------+
-
| id | b | c |
-
+----+------+------+
-
| 1 | 2 | 3 |
-
| 2 | 2 | 4 |
-
+----+------+------+
-
2 rows in set (0.00 sec)
-
root@test 04:38:50>replace into yy values(1,2,5);
-
Query OK, 2 rows affected (0.00 sec)
-
root@test 04:38:58>select * from yy;
-
+----+------+------+
-
| id | b | c |
-
+----+------+------+
-
| 2 | 2 | 4 |
-
| 1 | 2 | 5 |
-
+----+------+------+
- 2 rows in set (0.00 sec)
-
BINLOG '
-
Io5hVROWYHC+KwAAAEICAAAAAMoMAAAAAAEABHRlc3QAAnl5AAMDAwMABg==
-
Io5hVRmWYHC+KgAAAGwCAAAAAMoMAAAAAAAAA//4AQAAAAIAAAADAAAA
-
### DELETE FROM test.yy
-
### WHERE
-
### @1=1 /* INT meta=0 nullable=0 is_null=0 */
-
### @2=2 /* INT meta=0 nullable=1 is_null=0 */
-
### @3=3 /* INT meta=0 nullable=1 is_null=0 */
-
Io5hVReWYHC+KgAAAJYCAAAAAMoMAAAAAAEAA//4AQAAAAIAAAAFAAAA
-
'/*!*/;
-
### INSERT INTO test.yy
-
### SET
-
### @1=1 /* INT meta=0 nullable=0 is_null=0 */
-
### @2=2 /* INT meta=0 nullable=1 is_null=0 */
-
### @3=5 /* INT meta=0 nullable=1 is_null=0 */
-
# at 662
-
#150524 16:38:58 server id 3195035798 end_log_pos 689 Xid = 22962508
- COMMIT/*!*/
-
root@test 04:48:30>select * from yy;
-
+----+------+------+
-
| id | b | c |
-
+----+------+------+
-
| 1 | 2 | 4 |
-
| 2 | 2 | 5 |
-
| 3 | 3 | 5 |
-
| 4 | 3 | 6 |
-
+----+------+------+
-
4 rows in set (0.00 sec)
-
root@test 04:53:21>replace into yy values(5,3,6);
-
Query OK, 2 rows affected (0.00 sec)
-
root@test 04:53:40>select * from yy;
-
+----+------+------+
-
| id | b | c |
-
+----+------+------+
-
| 1 | 2 | 4 |
-
| 2 | 2 | 5 |
-
| 3 | 3 | 5 |
-
| 5 | 3 | 6 |
-
+----+------+------+
- 4 rows in set (0.00 sec)
-
BINLOG \'
-
lJFhVROWYHC+KwAAANoAAAAAAMoMAAAAAAEABHRlc3QAAnl5AAMDAwMABg==
-
lJFhVRiWYHC+OAAAABIBAAAAAMoMAAAAAAEAA///+AQAAAADAAAABgAAAPgFAAAAAwAAAAYAAAA=
-
\'/*!*/;
-
### UPDATE test.yy
-
### WHERE
-
### @1=4 /* INT meta=0 nullable=0 is_null=0 */
-
### @2=3 /* INT meta=0 nullable=1 is_null=0 */
-
### @3=6 /* INT meta=0 nullable=1 is_null=0 */
-
### SET
-
### @1=5 /* INT meta=0 nullable=0 is_null=0 */
-
### @2=3 /* INT meta=0 nullable=1 is_null=0 */
-
### @3=6 /* INT meta=0 nullable=1 is_null=0 */
-
# at 274
-
#150524 16:53:40 server id 3195035798 end_log_pos 301 Xid = 22962872
- COMMIT/*!*/
-
root@test 04:53:52>replace into yy values(1,3,6);
-
Query OK, 3 rows affected (0.00 sec) ---注意此處影響的行數是3
-
root@test 04:55:35>select * from yy;
-
+----+------+------+
-
| id | b | c |
-
+----+------+------+
-
| 2 | 2 | 5 |
-
| 3 | 3 | 5 |
-
| 1 | 3 | 6 |
-
+----+------+------+
- 3 rows in set (0.00 sec)
-
BINLOG \'
-
B5JhVROWYHC+KwAAAJwBAAAAAMoMAAAAAAEABHRlc3QAAnl5AAMDAwMABg==
-
B5JhVRmWYHC+KgAAAMYBAAAAAMoMAAAAAAAAA//4AQAAAAIAAAAEAAAA
-
### DELETE FROM test.yy
-
### WHERE
-
### @1=1 /* INT meta=0 nullable=0 is_null=0 */
-
### @2=2 /* INT meta=0 nullable=1 is_null=0 */
-
### @3=4 /* INT meta=0 nullable=1 is_null=0 */
-
B5JhVRiWYHC+OAAAAP4BAAAAAMoMAAAAAAEAA///+AUAAAADAAAABgAAAPgBAAAAAwAAAAYAAAA=
-
\'/*!*/;
-
### UPDATE test.yy
-
### WHERE
-
### @1=5 /* INT meta=0 nullable=0 is_null=0 */
-
### @2=3 /* INT meta=0 nullable=1 is_null=0 */
-
### @3=6 /* INT meta=0 nullable=1 is_null=0 */
-
### SET
-
### @1=1 /* INT meta=0 nullable=0 is_null=0 */
-
### @2=3 /* INT meta=0 nullable=1 is_null=0 */
-
### @3=6 /* INT meta=0 nullable=1 is_null=0 */
-
# at 510
-
#150524 16:55:35 server id 3195035798 end_log_pos 537 Xid = 22962904
- COMMIT/*!*/
對錶進行replace into操作的時候,
當不存在衝突時,replace into 相當於insert操作。
當存在pk衝突的時候是先delete再insert,如果主鍵是自增的,則自增主鍵會做 +1 操作。【5.5,5.6版本均做過測試】
當存在uk衝突的時候是直接update。,如果主鍵是自增的,則自增主鍵會做 +1 操作。 【5.5,5.6版本均做過測試】
瞭解上述原理和結論之後,以後再遇到replace into 的時候,相信各位讀者可以知道如何選擇,由於篇幅限制,後續文章會基於replace into原理,講述生產過程中的注意事項。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26250550/viewspace-1674769/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 淺析MySQL replace into 的用法MySql
- 【MySQL】replace into 淺析之二MySql
- MYSQL INNODB replace into 死鎖 及 next key lock 淺析MySql
- MySQL Replication淺析MySql
- MySql(一) 淺析MySql索引MySql索引
- MySQL 高可用淺析MySql
- 【MySQL】gap lock 淺析MySql
- MySQL高可用淺析MySql
- 【MySQL】八、double write 淺析.MySql
- MySQL事務原理淺析MySql
- mysql之 double write 淺析MySql
- mysql replaceMySql
- MySql(四) InnoDB事務淺析MySql
- MySQL5.7GTID淺析MySql
- 淺析MySQL 8.0直方圖原理MySql直方圖
- 逆向淺析常見病毒的注入方式系列之一-----WriteProcessMemorySSM
- 淺析MySQL InnoDB的隔離級別MySql
- 技術分享 | MySQL : SSL 連線淺析MySql
- MySQL binlog相關原始碼淺析MySql原始碼
- 淺析Mysql的my.ini檔案MySql
- 【連載】淺析React生命週期之一:掛載階段React
- MySQL replace語句MySql
- MySQL伺服器連線過程淺析MySql伺服器
- 淺析MySQL事務中的redo與undoMySql
- MySQL的共享鎖阻塞會話案例淺析MySql會話
- MySQL效能最佳化淺析及線上案例MySql
- MySQL 非同步驅動淺析 (一):效能分析MySql非同步
- iOS Block淺淺析iOSBloC
- MYSQL中replace into的用法MySql
- mySQL中replace的用法MySql
- 淺析 JWTJWT
- MongoDB淺析MongoDB
- RunLoop 淺析OOP
- Nginx淺析Nginx
- 淺析 requestAnimationFramerequestAnimationFrame
- 淺析PromisePromise
- 淺析GitGit
- 淺析RedisRedis