目次
When to Use ON DUPLICATE KEY UPDATE
Basic Syntax
Example: Insert or Update a User's Login Count
Key Points to Remember
Practical Tips
Alternative: Use INSERT ... SET Syntax
ホームページ データベース mysql チュートリアル MySQLでONの重複キーアップデートステートメントを使用する方法は?

MySQLでONの重複キーアップデートステートメントを使用する方法は?

Aug 05, 2025 pm 02:34 PM

ON DUPLICATE KEY UPDATE 用于处理唯一键或主键冲突,1. 当插入数据出现重复时,不报错而是更新指定字段;2. 适用于计数器、数据同步等场景;3. 语法为 INSERT INTO ... VALUES ... ON DUPLICATE KEY UPDATE column = VALUES(column);4. VALUES(column) 获取原计划插入的值;5. 仅在发生唯一键冲突时触发更新;6. 每条重复记录独立处理;7. 需注意 AUTO_INCREMENT 和 TIMESTAMP 列的意外更新;8. 可避免先查后插的复杂逻辑,提升效率;9. 该语法为 MySQL 特有,非标准 SQL;10. 也可使用 INSERT INTO ... SET 格式提高可读性;该机制通过单条语句实现安全的插入或更新操作,前提是表已定义正确的唯一约束。

How to use the ON DUPLICATE KEY UPDATE statement in MySQL?

The ON DUPLICATE KEY UPDATE clause in MySQL is used with the INSERT statement to handle situations where a duplicate key conflict occurs—typically due to a duplicate entry in a unique index or primary key. Instead of letting the query fail, you can specify actions to update the existing row.

How to use the ON DUPLICATE KEY UPDATE statement in MySQL?

When to Use ON DUPLICATE KEY UPDATE

This is useful when you want to insert a new record, but if a duplicate key already exists, update specific fields rather than throwing an error. It’s commonly used in scenarios like counters, upserts (update or insert), or syncing data.


Basic Syntax

INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...)
ON DUPLICATE KEY UPDATE
    column1 = VALUES(column1),
    column2 = VALUES(column2),
    ...;
  • VALUES(column) refers to the value that would have been inserted for that column.
  • The update part only runs if a duplicate key is found.

Example: Insert or Update a User's Login Count

Suppose you have a users table:

How to use the ON DUPLICATE KEY UPDATE statement in MySQL?
CREATE TABLE users (
    id INT PRIMARY KEY,
    username VARCHAR(50) UNIQUE,
    login_count INT DEFAULT 0,
    last_login TIMESTAMP
);

You want to insert a new user, or if the user already exists (by username or id), just increment their login count and update the timestamp.

INSERT INTO users (id, username, login_count, last_login)
VALUES (1, 'john_doe', 1, NOW())
ON DUPLICATE KEY UPDATE
    login_count = login_count + 1,
    last_login = NOW();
  • If user with id=1 doesn’t exist → insert the row.
  • If user with id=1 already exists → increment login_count and update last_login.

Key Points to Remember

  • Only triggers on unique key or primary key violations.
    The ON DUPLICATE KEY UPDATE only activates if the INSERT would cause a duplicate in a UNIQUE index or PRIMARY KEY.

    How to use the ON DUPLICATE KEY UPDATE statement in MySQL?
  • Use VALUES() to access the attempted insert values.
    VALUES(column) gives you the value you tried to insert, which is helpful for clean upsert logic.

  • Only one row is updated per duplicate.
    If multiple rows cause duplicates in a multi-row INSERT, each is handled individually.

  • Be cautious with auto-increment and timestamps.
    If you’re not careful, ON DUPLICATE KEY UPDATE might trigger unintended updates on AUTO_INCREMENT or TIMESTAMP columns.


Practical Tips

  • You can set only some fields in the update, not all.
  • Use it to avoid having to SELECT first and then conditionally INSERT or UPDATE—this is more efficient.
  • It’s not standard SQL, so it’s MySQL-specific. Other databases use MERGE, UPSERT, or ON CONFLICT.

Alternative: Use INSERT ... SET Syntax

You can also write it using SET:

INSERT INTO users
SET id = 1,
    username = 'john_doe',
    login_count = 1,
    last_login = NOW()
ON DUPLICATE KEY UPDATE
    login_count = login_count + 1,
    last_login = NOW();

This format can be more readable for complex inserts.


Basically, ON DUPLICATE KEY UPDATE is a powerful way to handle conflicts gracefully in MySQL with a single query. Just make sure your table has the right unique constraints in place.

以上がMySQLでONの重複キーアップデートステートメントを使用する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

MySQLクエリパフォーマンスの最適化の戦略 MySQLクエリパフォーマンスの最適化の戦略 Jul 13, 2025 am 01:45 AM

MySQLクエリパフォーマンスの最適化は、インデックスの合理的な使用、SQLステートメントの最適化、テーブル構造設計とパーティション戦略、キャッシュおよび監視ツールの利用など、コアポイントから開始する必要があります。 1.合理的にインデックスを使用する:一般的に使用されるクエリフィールドでインデックスを作成し、完全なテーブルスキャンを避け、結合されたインデックス順序に注意を払い、低い選択フィールドにインデックスを追加しないでください。 2。SQLクエリの最適化:Select*を避け、Whereで機能を使用しないでください。サブクエリネスティングを削減し、ページングクエリメソッドを最適化します。 3。テーブル構造の設計とパーティション化:読み取りおよび書き込みシナリオに従ってパラダイムまたはアンチパラダイムを選択し、適切なフィールドタイプを選択し、定期的にデータをクリーンし、水平テーブルを検討して、テーブルまたはパーティションを時間単位で分割します。 4.キャッシュと監視の利用:Redisキャッシュを使用してデータベースの圧力を下げ、遅いクエリを有効にします

SSL/TLS暗号化によるMySQL接続を保護します SSL/TLS暗号化によるMySQL接続を保護します Jul 21, 2025 am 02:08 AM

なぜSSL/TLS暗号化mysql接続が必要なのですか?暗号化されていない接続が機密データを傍受する可能性があるため、SSL/TLSを有効にすると、中間の攻撃を防ぎ、コンプライアンス要件を満たすことができます。 2.MySQL用のSSL/TLSを構成する方法は?証明書と秘密鍵を生成し、構成ファイルを変更してSSL-CA、SSL-CERT、SSL-KEYパスを指定してサービスを再起動する必要があります。 3.クライアントが接続したときにSSLを強制する方法は?ユーザーを作成するときにrequesslまたはrequenex509を指定することにより実装されます。 4。SSL構成で簡単に見落とされる詳細には、証明書パス許可、証明書の有効期限の問題、クライアント構成要件が含まれます。

ExcelをMySQLデータベースに接続する方法 ExcelをMySQLデータベースに接続する方法 Jul 16, 2025 am 02:52 AM

ExcelをMySQLデータベースに接続するには3つの方法があります。1。PowerQueryの使用:MySQLODBCドライバーをインストールした後、Excelの組み込みPowerQuery機能を介して接続を確立し、データをインポートし、タイミングの更新をサポートします。 2。MySQLForexcelプラグインを使用します。公式プラグインは、フレンドリーなインターフェイスを提供し、双方向の同期とテーブルのインポートをMySQLにサポートし、バージョンの互換性に注意してください。 3. VBA ADOプログラミングを使用:上級ユーザーに適しており、マクロコードを作成して柔軟な接続とクエリを実現します。ニーズと技術レベルに応じて適切な方法を選択してください。 PowerQueryまたはMySqlForexcelは毎日の使用に推奨され、VBAは自動処理に適しています。

MySQL Common Table Expression(CTE)の例 MySQL Common Table Expression(CTE)の例 Jul 14, 2025 am 02:28 AM

CTEは、複雑なクエリを簡素化するために使用されるMySQLの一時的な結果です。現在のクエリで複数回参照して、コードの読みやすさとメンテナンスを改善することができます。たとえば、注文テーブルで各ユーザーの最新の注文を探している場合、最初に各ユーザーの最新の注文日をCTEから取得し、元のテーブルに関連付けて完全なレコードを取得できます。サブQueriesと比較して、CTE構造はより明確で、ロジックはデバッグしやすくなります。使用のヒントには、明示的なエイリアス、複数のCTEの連結、再帰CTEを使用したツリーデータの処理が含まれます。 CTEをマスターすると、SQLがよりエレガントで効率的になります。

MySQLテーブルの列の適切なデータ型を選択します MySQLテーブルの列の適切なデータ型を選択します Jul 15, 2025 am 02:25 AM

settingupmysqltablesの場合、therightdatatypesiscialforefficanity andscalabilityを選択します

コードとしてインフラストラクチャを使用してMySQLの展開を自動化します コードとしてインフラストラクチャを使用してMySQLの展開を自動化します Jul 20, 2025 am 01:49 AM

MySQL展開自動化を実現するために、重要なのはTerraformを使用してリソース、Ansible管理構成、バージョン制御用のGIT、およびセキュリティと許可管理を強化することです。 1. Terraformを使用して、バージョン、タイプ、アクセス制御、およびAWSRDSのその他のリソース属性などのMySQLインスタンスを定義します。 2。ansiblePlaybookを使用して、データベースユーザーの作成、許可設定などの詳細な構成を実現します。 3.すべての構成ファイルは、GIT管理に含まれ、変更の変更と共同開発をサポートします。 4.ハードコーディングされた機密情報を避け、VaultまたはAnsibleVaultを使用してパスワードを管理し、アクセス制御と最小許可原則を設定します。

mysqlで半同期複製をセットアップします mysqlで半同期複製をセットアップします Jul 15, 2025 am 02:35 AM

MySQL Semi-Synchronous Replicationを設定するための手順は次のとおりです。1。バージョンを確認して、プラグインをサポートしてロードします。 2。電源を入れて、半同期モードを有効にします。 3.ステータスと操作ステータスを確認します。 4.タイムアウト設定、マルチスレーブライブラリの構成、マスタースレーブスイッチング処理に注意してください。 MySQL 5.5以降のバージョンがインストールされていることを確認する必要があります。RPL_SEMI_SYNC_MASTER、RPL_SEMI_SYNC_SLAVEプラグインを確実にし、マスターとスレーブライブラリの対応するパラメーターを有効にし、My.CNFで自動荷重を設定し、サービスを再起動した後にサービスを再開します。

mysql列の文字列値が正しくありません mysql列の文字列値が正しくありません Jul 15, 2025 am 02:40 AM

mySQLエラー「違反するValueForColumn」は、通常、フィールド文字セットが絵文字などの4バイト文字をサポートしていないためです。 1。エラーの原因:MySQLのUTF8文字セットは3バイト文字のみをサポートし、4バイトの絵文字を保存できません。 2。ソリューション:データベース、テーブル、フィールド、および接続をUTF8MB4文字セットに変更します。 3.構成ファイル、一時テーブル、アプリケーションレイヤーエンコード、クライアントドライバーがすべてUTF8MB4をサポートするかどうかを確認します。 4.代替ソリューション:4バイト文字をサポートする必要がない場合は、アプリケーションレイヤーで絵文字などの特殊文字をフィルタリングできます。

See all articles