MySQL の LOAD DATA INFILE を使用した ON DUPLICATE KEY UPDATE のエミュレーション
MySQL の LOAD DATA INFILE は、大規模なデータセットを迅速にインポートするための強力なツールです。ただし、ON DUPLICATE KEY UPDATE 句はサポートされていないため、データの不整合やパフォーマンスの問題が発生する可能性があります。この制限を回避するには、別のアプローチが必要です。
ON DUPLICATE KEY UPDATE 機能をエミュレートするには、次の手順を検討してください。
1.一時テーブルを作成します:
CREATE TEMPORARY TABLE temporary_table LIKE target_table;
2.一時テーブルの最適化 (オプション):
一時テーブルからインデックスを削除してデータの読み込みを高速化します:
SHOW INDEX FROM temporary_table; DROP INDEX `PRIMARY` ON temporary_table; DROP INDEX `some_other_index` ON temporary_table;
3. CSV を一時テーブルにロードします:
LOAD DATA INFILE を使用して基本的なデータ インポートを実行します:
LOAD DATA INFILE 'your_file.csv' INTO TABLE temporary_table FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' (field1, field2);
4. ON DUPLICATE KEY UPDATE でデータをコピーします:
既存のレコードを保持しながらターゲット テーブルを更新します:
SHOW COLUMNS FROM target_table; INSERT INTO target_table SELECT * FROM temporary_table ON DUPLICATE KEY UPDATE field1 = VALUES(field1), field2 = VALUES(field2);
5.一時テーブルの削除:
データ転送が完了したら、一時テーブルを破棄します:
DROP TEMPORARY TABLE temporary_table;
これらの手順に従うことで、LOAD DATA を使用して ON DUPLICATE KEY UPDATE 機能をエミュレートできます。 INFILE、データの整合性を維持しながらデータの読み込みを最適化します。
以上がMySQL で LOAD DATA INFILE を使用して ON DUPLICATE KEY UPDATE を模倣するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。