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
을 사용하는 사용자의 desiredWeight
및 id = 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!