ホームページ >データベース >mysql チュートリアル >MySQL で LOAD DATA INFILE を使用して ON DUPLICATE KEY UPDATE を模倣するにはどうすればよいですか?

MySQL で LOAD DATA INFILE を使用して ON DUPLICATE KEY UPDATE を模倣するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-27 00:32:14763ブラウズ

How Can I Mimic ON DUPLICATE KEY UPDATE Using LOAD DATA INFILE in MySQL?

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。