> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 WHERE 절을 사용하면 INSERT 쿼리가 실패하는 이유는 무엇입니까?

MySQL에서 WHERE 절을 사용하면 INSERT 쿼리가 실패하는 이유는 무엇입니까?

DDD
풀어 주다: 2025-01-19 06:40:10
원래의
966명이 탐색했습니다.

Why Do INSERT Queries Fail with a WHERE Clause in MySQL?

MySQL INSERT 문 및 WHERE 절: 일반적인 함정

MySQL INSERT 문에서 WHERE 절을 사용하면 오류가 발생합니다. 이는 WHERE 절이 INSERT가 아닌 UPDATE 및 DELETE 작업을 위해 특별히 설계되었기 때문입니다.

제공된 쿼리의 목적은 새 사용자를 추가하거나 기존 사용자를 수정하는 것입니다. 두 가지 시나리오를 모두 명확하게 설명하겠습니다.

새 사용자 추가

ID 1의 새 사용자를 삽입하려면 올바른 MySQL 구문은 다음과 같습니다.

<code class="language-sql">INSERT INTO Users (id, weight, desiredWeight) VALUES (1, 160, 145);</code>
로그인 후 복사

id, weight, desiredWeight에 값을 직접 할당하여 새로운 사용자 레코드를 생성합니다.

기존 사용자 수정

기존 사용자를 업데이트하는 것이 목표인 경우 UPDATE 문을 사용하세요.

<code class="language-sql">UPDATE Users SET weight = 160, desiredWeight = 145 WHERE id = 1;</code>
로그인 후 복사

이렇게 하면 다른 항목에 영향을 주지 않고 weight을 사용하는 사용자의 desiredWeightid = 1이 변경됩니다.

대체 방법: 조건부 삽입 및 업데이트

기록 존재 여부에 따라 삽입과 업데이트를 모두 처리하려면 다음 대안을 고려하세요.

  • INSERT ... ON DUPLICATE KEY UPDATE:
<code class="language-sql">INSERT INTO Users (id, weight, desiredWeight) VALUES (1, 160, 145) ON DUPLICATE KEY UPDATE weight = 160, desiredWeight = 145;</code>
로그인 후 복사

키가 존재하지 않으면 새 행을 삽입합니다. 그렇지 않으면 기존 행을 업데이트합니다.

  • INSERT ... SET: (기능적으로는 위의 VALUES 메소드와 유사하지만 이 구문은 명확성을 위해 덜 선호되는 경우가 많습니다.)

기억하세요: id이 자동 증가 열인 경우 INSERT 문에서 이를 생략할 수 있습니다. MySQL은 자동으로 고유 ID를 생성합니다.

위 내용은 MySQL에서 WHERE 절을 사용하면 INSERT 쿼리가 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿