고유 제약 조건을 위반하지 않고 MySQL에서 행 값 교환
MySQL에서는 테이블의 두 행 값을 교환해야 하는 경우가 많습니다. 특정 열에 대한 고유 제약 조건을 유지하면서. 그러나 CASE 절과 함께 일반적인 UPDATE 문을 사용하면 고유 제약 조건을 위반할 경우 중복 항목 오류가 발생할 수 있습니다.
문제
문제는 MySQL 때문에 발생합니다. 업데이트를 행별로 처리하고 각 변경 후 고유 제약 조건 위반을 확인합니다. 제공된 예에서:
UPDATE tasks SET priority = CASE WHEN priority=2 THEN 3 WHEN priority=3 THEN 2 END WHERE priority IN (2,3);
MySQL은 우선순위가 2인 첫 번째 행을 우선순위 3으로 업데이트합니다. 그러나 우선순위가 3인 두 번째 행을 우선순위 2로 업데이트하려고 하면 위반이 발생합니다.
해결책
안타깝게도 가짜 값이나 다중 쿼리를 사용하지 않고는 MySQL에서 행 값 교환을 수행하는 것이 불가능합니다. 이는 MySQL의 고유한 제약 조건 처리 동작 때문입니다.
이 제한을 해결하려면 트랜잭션에 래핑된 다음 두 문 접근 방식을 활용할 수 있습니다.
START TRANSACTION ; UPDATE tasks SET priority = CASE WHEN priority = 2 THEN -3 WHEN priority = 3 THEN -2 END WHERE priority IN (2,3) ; UPDATE tasks SET priority = - priority WHERE priority IN (-2,-3) ; COMMIT ;
이 접근 방식은 값을 효과적으로 교환합니다. 임시 자리 표시자로 음수 값을 할당합니다. 트랜잭션 내에서 MySQL은 업데이트를 단일 작업으로 간주하여 고유 제약 조건 위반을 방지합니다.
위 내용은 고유 제약 조건을 존중하면서 MySQL에서 행 값을 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!