在同步數據的時候,有這樣常見的的操作:
1、插入一行數據,如果存在則不插入;
2、插入一行數據,如果存在則執行更新操作。
以下是例子。
建表語句:
CREATE TABLE `student` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`useruuid` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`name` varchar(255) DEFAULT NULL,
`createtime` datetime DEFAULT NULL,
`updatetime` datetime DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `unique_index_useruuid` (`useruuid`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
PS:useruuid字段設置爲唯一索引
使用insert ignore into
,實現插入一行數據,如果存在則不插入了。
效果:多次執行下面這條語句,程序也不會報錯:
insert ignore into student(age,name,useruuid,createtime)
values (10,'lee','4eb5a467-103c-11ea-b82b-c81fbecfcb98',now())
使用insert into ... on duplicate key update
,實現插入一行數據,如果存在則執行更新操作 ,前提是useruuid有唯一索引:
//插入一條數據,如果存在則更新updatetime字段
insert into student(age,name,useruuid,createtime) values (11,'jack','4eb5a467-103c-11ea-0000-c81fbecfcb98',now())
on duplicate key update updatetime = now();
對於上面第二個例子中只是刷新updatetime,可能不太好理解。在實際場景中,如定時同步監控設備信息,如果該設備的記錄已經存在於表中,則更新該設備的運行狀態status、更新時間updatetime等字段。