>  기사  >  데이터 베이스  >  고유 제약 조건을 존중하면서 MySQL에서 행 값을 바꾸는 방법은 무엇입니까?

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

Linda Hamilton
Linda Hamilton원래의
2024-10-26 14:42:02622검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.