最近、MySQL を勉強しているときに、MySQL のバッチ挿入とバッチ更新の効率が低いという問題に遭遇しました。以前から SQL Server を使用していましたが、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;
クエリ最適化、シナリオは試験コードが存在するかどうかを判断することです
SELECT 1 FROM b_student WHERE examcode='10001' limit 1;
クエリ結果1は存在することを意味し、結果nullはそれを意味します存在しません
一括挿入最適化、生徒情報のシナリオ一括挿入
INSERT INTO `b_student` (`examcode`,`stucode`,`name`) VALUES('10001','10001','张三'),('10002','10002','李四');
一括更新最適化、生徒情報のシナリオ一括更新
一括挿入 ここでは2つの方法(テーブルに主キーが必要です)などの方法があります。
1. replace into メソッドは、主キーに基づいて特定の列を更新します。 注: このメソッドは、ID と名前を除く列をクリアします。
replace into b_student (id,name) values (1,'张三丰'),(2,'李思思');
2. 重複キー更新メソッドで ... に挿入し、主キーに従って更新後に定義された列を更新します
insert into b_student (id,stucode) values (1,'20001'),(2,'20002') on duplicate key update stucode=values(stucode);
上記の 2 つのメソッドは、状況に応じてバッチ更新で非常に効率的です。実際の状況に応じて選択してください。
上記は、MySQL クエリ、バッチ挿入、バッチ更新、最適化の詳細な紹介です。その他の関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) に注目してください。