国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL replace into 語句淺析(一)

2024-07-24 12:45:59
字體:
來源:轉載
供稿:網友

一 介紹

  在筆者支持業務過程中,經常遇到開發咨詢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)

如果本來已經存在的主鍵值,那么MySQL做update操作。
復制代碼 代碼如下:

### 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 操作  replace into yy values(2,'bbb');
復制代碼 代碼如下:

### 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

2.2 當表中主鍵和唯一鍵同時存在時

復制代碼 代碼如下:

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

情形1 主鍵沖突
復制代碼 代碼如下:

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)
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昌黎县| 黑龙江省| 奈曼旗| 德令哈市| 广丰县| 益阳市| 宝丰县| 阿鲁科尔沁旗| 宁蒗| 梨树县| 哈尔滨市| 南召县| 阿坝| 澎湖县| 磐石市| 怀远县| 襄樊市| 新野县| 奈曼旗| 鹿邑县| 时尚| 永兴县| 收藏| 双鸭山市| 禄劝| 新郑市| 社会| 来安县| 兴文县| 阿巴嘎旗| 当阳市| 双桥区| 辰溪县| 攀枝花市| 焉耆| 台南县| 贵阳市| 中卫市| 改则县| 榆树市| 镇雄县|