>데이터 베이스 >MySQL 튜토리얼 >SQLite에서 MySQL의 ON DUPLICATE KEY UPDATE 기능을 어떻게 얻을 수 있습니까?

SQLite에서 MySQL의 ON DUPLICATE KEY UPDATE 기능을 어떻게 얻을 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-15 14:11:441040검색

How Can I Achieve MySQL's ON DUPLICATE KEY UPDATE Functionality in SQLite?

SQLite Upsert: MySQL의 ON DUPLICATE KEY 업데이트 기능 미러링

MySQL의 ON DUPLICATE KEY UPDATE은 고유 키 제약 조건을 기반으로 행 삽입 또는 업데이트를 단순화합니다. 이 단일 쿼리는 키가 고유한 경우 새 행을 삽입하거나 중복 키가 발견된 경우 기존 행을 업데이트합니다. SQLite에는 이와 직접적으로 동등한 기능이 없습니다.

SQLite의 Upsert에 대한 해결 방법

SQLite는 동일한 결과를 얻기 위한 대체 전략을 제공합니다.

1. 선택 후 삽입 또는 업데이트:

이 방법은 두 가지 쿼리를 사용합니다.

  • 주어진 키를 가진 행이 있는지 확인하는 SELECT 쿼리입니다.
  • INSERT 쿼리 결과에 따른 UPDATE 또는 SELECT 쿼리

이 접근 방식에는 두 가지 데이터베이스 상호 작용이 필요하며 잠재적으로 성능에 영향을 미칠 수 있습니다.

2. 업데이트 후 실패 시 삽입:

여기에는 오류 처리가 포함된 단일 UPDATE 쿼리가 포함됩니다.

  • 성공적인 UPDATE은 기존 행을 나타내며 데이터가 업데이트되었음을 ​​나타냅니다.
  • 실패한 UPDATE(행이 존재하지 않기 때문에)은 INSERT 쿼리
  • 를 트리거합니다.

이렇게 하면 데이터베이스 호출이 하나로 줄어들지만 실패한 INSERT 시도(예: 중복 키로 인해)에 대한 추가 오류 처리가 필요합니다.

최적의 SQLite Upsert 전략

가장 효율적이고 강력한 SQLite upsert 방법은 INSERT OR IGNOREUPDATE을 결합합니다.

<code class="language-sql">INSERT OR IGNORE INTO visits VALUES ($ip, 0);
UPDATE visits SET hits = hits + 1 WHERE ip LIKE $ip;</code>

이를 위해서는 "ip" 열에 UNIQUE 또는 PRIMARY KEY 제약 조건이 필요합니다. INSERT OR IGNORE 삽입을 시도합니다. 중복 키가 있으면 자동으로 무시됩니다. 그런 다음 후속 UPDATE은 기존 행의 적중 횟수를 증가시킵니다. 이 솔루션은 효율성(단일 데이터베이스 왕복)을 제공하고 중복 키 삽입으로 인한 오류를 방지합니다.

위 내용은 SQLite에서 MySQL의 ON DUPLICATE KEY UPDATE 기능을 어떻게 얻을 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.