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

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

Linda Hamilton
Linda Hamilton원래의
2024-10-26 04:23:31250검색

 How to Swap Row Values in MySQL with a Unique Constraint?

고유 제약 조건을 사용하여 행 값을 교환하는 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이 각 행 업데이트 후에 제약 조건 검사를 시행하기 때문입니다.

대체 접근 방식:

제약 조건을 위반하지 않고 값을 교환하려면 다음을 사용할 수 있습니다. 트랜잭션 내의 다음 단계:

  1. 가짜 값으로 행 업데이트: 한 행의 우선순위를 존재하지 않는 음수 값(-2)으로 설정하고 다른 행을 다음으로 설정합니다. 또 다른 음수 값(-3).
  2. 음수 값을 사용하여 값 교환: 우선순위를 교환하려면 가짜 값(-priority)을 무효화합니다.
  3. 거래: 변경 사항을 영구적으로 적용합니다.

거래 명세서:

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

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