SQL만 사용하여 PostgreSQL에서 업데이트 후 이전 열 값을 검색하는 방법은 무엇입니까?
Jan 06, 2025 am 12:52 AMSQL만 사용하여 사전 업데이트 열 값을 얻는 방법
문제:
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

일반적인 취약점 (SQL 주입, 무차별 적 공격)에 대해 MySQL을 어떻게 보호합니까?

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)?
