mysql實現merge功能之DUPLICATE key UPDATE語法
知識點
mysql提供了DUPLICATE key UPDATE語法可以實現類似oracle中的merge功能,當表中存在資料的時候(根據主鍵判斷),就更新記錄,不存在的時候則插入資料,相關語法如下:
insert into tb1(col1,col2) select cola,colb from tb2 on DUPLICATE key UPDATE cola=values(cola);
注意:
-
values(cola)語法僅能用於insert select語句中,這裡也可以是你想要的任何合法的值
-
update後面跟所有需要更新的欄位
-
為了提高效能,建議在insert into tbname後面列出所有需要的欄位名
-
該語法對於單條記錄執行更新操作,返回的影響條數為2,執行插入操作,返回的影響條數為1,不執行操作,返回影響條數為0
實驗例子
person表結構和記錄如下
CREATE TABLE `PERSON` ( `id` int(8) NOT NULL, `name` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '姓名', `age` int(3) DEFAULT NULL COMMENT '年齡', `sex` varchar(8) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '性別', `height` double(6,2) DEFAULT NULL COMMENT '身高(cm)', `weight` double(6,2) DEFAULT NULL COMMENT '體重(kg)', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
person_temp
CREATE TABLE `PERSON_TEMP` ( `id` int(8) NOT NULL, `name` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '姓名', `age` int(3) DEFAULT NULL COMMENT '年齡', `sex` varchar(8) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '性別', `height` double(6,2) DEFAULT NULL COMMENT '身高(cm)', `weight` double(6,2) DEFAULT NULL COMMENT '體重(kg)' ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
現在需要用person_temp表中的資料去更新person表的資料,根據上面的資料分析可知,person表的主鍵為id,person——temp的兩條記錄一條對應執行update,一條執行insert,返回影響條數為3。下面我們驗證一下。
執行語句:
INSERT into PERSON select * from PERSON_TEMP on DUPLICATE key UPDATE id=values(id), name=values(name), age=values(age), sex=values(sex), height=values(height), weight=values(weight);
返回結果如下:
執行上述語句後person表的記錄如下:
跟先前的資料比對,我們發現id=1的記錄被更新了,插入了一條id=6的記錄,執行結果返回的影響條數為3,與我們設想的一樣。
自動生成語句
實際環境中,我們需要處理的表欄位數可能是幾十個上百個的,這時候手動寫insert select on DUPLUCATEE KEY UPDATE是極其麻煩的,我根據person以及person_temp表的關係,寫了自動生成 on DUPLUCATEE KEY UPDATE語句的語法,大家有需要可以借鑑參考一下:
----information_schema使用者下執行語句 SELECT CONCAT( 'INSERT into ', UPPER( TABLE_NAME ), ' select * from ', UPPER( TABLE_NAME ), '_TEMP on DUPLICATE key UPDATE ', GROUP_CONCAT( a.colmap ORDER BY a.ORDINAL_POSITION )) FROM ( SELECT CONCAT( COLUMN_NAME, '=values(', COLUMN_NAME, ')' ) colmap, TABLE_NAME, ORDINAL_POSITION FROM `COLUMNS` WHERE TABLE_SCHEMA = 'testdb' AND table_name = 'PERSON' ORDER BY ORDINAL_POSITION ) AS a;
生成的結果就是我們上面執行的語句
INSERT into PERSON select * from PERSON_TEMP on DUPLICATE key UPDATE id=values(id), name=values(name), age=values(age), sex=values(sex), height=values(height), weight=values(weight)
注意:mysql預設 group_concat()返回的長度限制為1024,在上述語句中,當欄位數較多的時候,會返回不完整的語句,要根據需要設定引數:
永久方法:
在my.cnf加上引數 group_concat_max_len = 102400
臨時方法:
SET GLOBAL group_concat_max_len = 102400;
SET SESSION group_concat_max_len = 102400;
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31374736/viewspace-2790722/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL_插入更新 ON DUPLICATE KEY UPDATEMySql
- MySQL insert on duplicate key update 死鎖MySql
- MySQL 關於 INSERT INTO...ON DUPLICATE KEY UPDATE 的使用MySql
- on duplicate key update簡單使用
- BUG: pymysql executemany不支援insert on duplicate key updateMySql
- mysql update join,insert select 語法MySql
- 翻譯:insert on duplicate key update(已提交到MariaDB官方手冊)
- Merge語法限制
- SQL Server的Merge —— 一步實現 insert,update,deleteSQLServerdelete
- KunlunDB功能之insert/update/delete...returning語句delete
- MYSQL報1022錯誤:Can't write;duplicate key in table '.....'MySql
- SQL 高階語法 MERGE INTOSQL
- MySQL 06 mysql 如何實現類似 oracle 的 merge intoMySqlOracle
- vue報錯之Duplicate keys detected: '0'. This may cause an update error.VueError
- ERROR 1062 (23000): Duplicate entry for key 'PRIMARY'Error
- MogDB/openGauss中merge的語法解析
- Sqlserver、oracle中Merge的使用方法,一個merge語句搞定多個Insert,Update,Delete操作SQLServerOracledelete
- MySQL -update語句流程總結MySql
- MySQL的update語句避坑MySql
- mysql實現nextVal功能MySql
- JS中for(var key in o )語法JS
- Window Application has "update" key wordsAPP
- Linux學習之出現無法apt-get updateLinuxapt-get
- MySQL基礎語法實踐MySql
- 簡單分析MySQL中的primary key功能MySql
- Oracle中 Update和insert結合語法Oracle
- Qt中文字編輯器實現語法高亮功能(Qscitinlla)QT
- percona-toolkit之pt-index-usage和pt-duplicate-key-checker詳解Index
- MySQL update ...set後的and寫法的邏輯MySql
- MySQL 優化之 index_merge (索引合併)MySql優化Index索引
- MySQL資料災難挽救之Delete\UpdateMySqldelete
- MySQL Join語法MySql
- 常用MySQL語法MySql
- mysql基本語法MySql
- MYSQL語法(一)MySql
- mysql 語法1MySql
- Java中List集合轉Map集合報錯:Duplicate keyJava
- DUMP-CX_SY_OPEN_SQL_DB-DBSQL_DUPLICATE_KEY_ERRORSQLError