MySQL 查詢 批次插入 批次更新 最佳化的詳情介紹

黄舟
發布: 2017-03-04 14:36:42
原創
2163 人瀏覽過

最近在研究mysql的時候,遇到了mysql批量插入、批量更新效率不高的問題,之前一直在用sqlserver,mysql本身效率還是不錯的,這裡把提升效率方法記錄下,就不對比時間了,實際測試結果效率提升很多。

建立表格結構

1 DROP TABLE IF EXISTS `b_student`;
2 CREATE TABLE `b_student` (
3   `id` int(11) NOT NULL AUTO_INCREMENT,
4   `examcode` varchar(20) CHARACTER SET gbk NOT NULL DEFAULT '',
5   `stucode` varchar(20) CHARACTER SET gbk NOT NULL DEFAULT '',
6   `name` varchar(20) CHARACTER SET gbk NOT NULL DEFAULT '',
7   PRIMARY KEY (`id`)
8 ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
登入後複製

查詢最佳化,場景是判斷examcode是否存在

SELECT 1 FROM b_student WHERE examcode='10001'  limit 1;
登入後複製

查詢結果1表示存在,結果null表示不存在

 

#批次插入最佳化,場景批次插入學生資訊

INSERT INTO `b_student` (`examcode`,`stucode`,`name`) VALUES('10001','10001','张三'),('10002','10002','李四');
登入後複製

批次更新最佳化,場景批次更新學生資訊

批次插入這裡介紹兩種方法(要求表有主鍵),還有其他的方式。

1、replace into方法,根據主鍵更新某一列或某幾列,注意:這種方式會把除id和name之外的列清空。

replace into b_student (id,name) values (1,'张三丰'),(2,'李思思');
登入後複製

2、insert into ...on duplicate key update 方法,根據主鍵更新update後定義的列

#
insert into b_student (id,stucode) values (1,'20001'),(2,'20002') on duplicate key update stucode=values(stucode);
登入後複製

以上兩種方法在批次更新時效率非常高,根據實際情況進行選擇。

 以上就是MySQL 查詢 大量插入 大量更新 優化的詳情介紹的內容,更多相關內容請關注PHP中文網(www.php.cn)!


#
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!