> 데이터 베이스 > MySQL 튜토리얼 > SQL만 사용하여 PostgreSQL에서 업데이트 후 이전 열 값을 검색하는 방법은 무엇입니까?

SQL만 사용하여 PostgreSQL에서 업데이트 후 이전 열 값을 검색하는 방법은 무엇입니까?

DDD
풀어 주다: 2025-01-06 00:52:39
원래의
262명이 탐색했습니다.

How to Retrieve Old Column Values After an UPDATE in PostgreSQL Using Only SQL?

SQL만 사용하여 사전 업데이트 열 값을 얻는 방법

문제:

PostgreSQL에서는 사전 업데이트 열 값 검색을 허용하지 않습니다. UPDATE 문의 RETURNING 절에서 열 값을 업데이트합니다. 이는 트리거나 프로시저와 같은 추가 메커니즘을 사용하지 않고 업데이트된 열의 이전 값을 얻으려고 할 때 문제가 됩니다.

셀프 조인을 사용하는 솔루션:

한 가지 솔루션 FROM 절에서 자체 조인을 활용하는 것입니다. 이 기술은 테이블의 복사본을 효과적으로 생성하고 업데이트된 값과 업데이트 전 값을 모두 참조할 수 있게 해줍니다.

UPDATE tbl x
SET    tbl_id = 23
     , name = 'New Guy'
FROM   tbl y                -- Using the FROM clause
WHERE  x.tbl_id = y.tbl_id  -- Must be UNIQUE NOT NULL
AND    x.tbl_id = 3
RETURNING y.tbl_id AS old_id, y.name AS old_name
        , x.tbl_id          , x.name;
로그인 후 복사

이 방법에는 자체 조인을 위해 UNIQUE NOT NULL 열이 필요하며 각 행이 일치하는지 확인합니다. 결합된 인스턴스의 단일 대응 항목으로.

동시 쓰기 솔루션 로드:

쓰기 동시성이 많은 시나리오에서는 경합 상태를 방지하기 위한 두 가지 옵션이 있습니다.

옵션 1: 직렬화 가능 격리 수준:

SERIALIZABLE 격리 수준을 활용하면 트랜잭션 실행 중 행에 대한 독점 액세스가 보장되므로 동시 발생이 방지됩니다. 쓰기:

BEGIN ISOLATION LEVEL SERIALIZABLE;
UPDATE ... ;
COMMIT;
로그인 후 복사

옵션 2: 명시적 잠금:

또는 명시적 잠금을 사용하여 행의 동시 업데이트를 방지할 수 있습니다.

UPDATE tbl x
SET    tbl_id = 24
     , name = 'New Gal'
FROM  (SELECT tbl_id, name FROM tbl WHERE tbl_id = 4 FOR UPDATE) y 
WHERE  x.tbl_id = y.tbl_id
RETURNING y.tbl_id AS old_id, y.name AS old_name
        , x.tbl_id          , x.name;
로그인 후 복사

위 내용은 SQL만 사용하여 PostgreSQL에서 업데이트 후 이전 열 값을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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