고유 제약 조건을 사용하여 행 값을 교환하는 MySQL
MySQL에서 우선 순위 열에 대한 고유 제약 조건을 사용하여 두 행의 우선 순위 값을 교환하는 것은 다음과 같습니다. 문제입니다.
문제:
이 문을 사용하여 값을 바꿀 때:
UPDATE tasks SET priority = CASE WHEN priority=2 THEN 3 WHEN priority=3 THEN 2 END WHERE priority IN (2,3);
중복 항목 위반으로 인해 오류가 발생합니다. 고유 제약 조건.
해결책:
안타깝게도 MySQL에서는 여러 쿼리나 가짜 값을 사용하지 않고 값을 교환하는 것이 불가능합니다. 이는 다른 DBMS와 달리 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에서 행 값을 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!