20190324 mysql實用操作

在同步數據的時候,有這樣常見的的操作:
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等字段。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章