>  기사  >  데이터 베이스  >  필드 존재 여부에 따라 MySQL에서 행을 업데이트하거나 삽입하는 방법은 무엇입니까?

필드 존재 여부에 따라 MySQL에서 행을 업데이트하거나 삽입하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-13 09:58:02571검색

How to Update or Insert Rows in MySQL Based on Field Presence?

MySQL: 필드 존재에 따라 업데이트 또는 삽입

문제 설명

코드에서 set_colors 테이블의 행을 업데이트하려고 합니다. 이미 존재하는 경우. 그렇지 않으면 새 행을 삽입하십시오. 그러나 쿼리 내에서 IF EXISTS 조건을 사용하고 있는데, 이는 이러한 시나리오를 처리하는 데 선호되는 방법과 일치하지 않습니다.

해결책

원하는 업데이트 또는 삽입 작업을 기반으로 수행하려면 필드가 있으면 INSERT ... ON DUPLICATE KEY UPDATE 구문 사용을 고려하세요.

INSERT INTO <table name> (field1, field2, field3, ...) 
VALUES ('value1', 'value2', 'value3', ...)
ON DUPLICATE KEY UPDATE
field1='value1', field2='value2', field3='value3', ...

설명

이 구문 사용:

  • 행이 필드에 없으면 지정된 기본 키(또는 고유 인덱스)가 없으면 제공된 값과 함께 삽입됩니다.
  • 행이 이미 존재하는 경우 지정된 필드가 업데이트됩니다. 제공된 값으로.
  • 행이 존재하고 제공된 값이 현재 값과 동일한 경우 아무 조치도 취하지 않으며 영향을 받는 행 개수는 0이 됩니다.

다음 쿼리는 사용법을 보여줍니다.

INSERT INTO set_colors (school_art_id, baseimage_id, sub_folder, layer)
VALUES ('1', '2', 'test-folder', '10')
ON DUPLICATE KEY UPDATE
baseimage_id='2',
sub_folder='updated-folder',
layer='15'
  • school_art_id 1이 없으면 제공된 값이 있는 새 행을 삽입합니다.
  • school_art_id 1이 이미 존재하는 경우 baseimage_id, sub_folder 및 레이어 필드가 제공된 값으로 업데이트됩니다.

위 내용은 필드 존재 여부에 따라 MySQL에서 행을 업데이트하거나 삽입하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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