고유 제약 조건을 존중하면서 MySQL에서 행 값을 바꾸는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-10-26 14:42:02
원래의
621명이 탐색했습니다.

How to Swap Row Values in MySQL While Respecting Unique Constraints?

고유 제약 조건을 위반하지 않고 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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