집 >데이터 베이스 >MySQL 튜토리얼 >SQLite에서 MySQL의 ON DUPLICATE KEY UPDATE 기능을 어떻게 얻을 수 있습니까?
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 IGNORE
과 UPDATE
을 결합합니다.
<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 중국어 웹사이트의 기타 관련 기사를 참조하세요!