또한 시퀀스의 다음 값을 변경해야 하는 상황이 발생하는 경우 시퀀스를 신속하게 재설정하고 테이블의 다음 항목에 대해 시작할 값을 지정할 수 있습니다. PostgreSQL에서 시퀀스를 재설정하는 방법과 관련하여 알아야 할 모든 세부 사항은 이 게시물에 자세히 설명되어 있습니다. 구경하다!
PostgreSQL에서 시퀀스를 재설정하는 방법에 대한 예
INT 열을 사용하면 자동 증가 시퀀스를 생성하고 이를 테이블의 기본 키로 사용할 수 있습니다. 이렇게 하면 정수 값이 자동으로 생성되므로 INSERT 쿼리를 실행할 때 해당 값을 입력할 필요가 없습니다. 시퀀스가 생성되면 ALTER SEQUENCE 명령을 사용하여 시퀀스를 다시 시작하고 새 항목에 대한 새 시작 값을 지정할 수 있습니다.
이 예에서는 다음 'user_details' 테이블을 사용하여 작업합니다. 우리의 초점은 100부터 시작하는 자동 증가 시퀀스인 'user_id' 열입니다.
데이터베이스의 다양한 시퀀스를 나열하려면 다음 명령을 실행하십시오.
\ds
우리의 경우 'user_id' 시퀀스를 대상으로 합니다.
시퀀스에 대한 자세한 내용을 보려면 다음과 같이 'select' 쿼리를 실행하세요.
SELECT * FROM 시퀀스_이름;
기존 시퀀스의 마지막 값이 104임을 알 수 있습니다. 이 값을 재설정하고 새 항목이 갖게 될 새 값을 정의합니다.
PostgreSQL 시퀀스를 재설정하려면 다음 명령을 사용하십시오.
ALTER SEQUENCE 시퀀스_이름 RESTART WITH 값;우리의 경우 시퀀스를 다시 시작하고 20에서 새 항목을 시작한다고 가정해 보겠습니다. 다음 명령을 실행하면 다음과 같이 시퀀스가 변경되었음을 확인하는 출력이 표시됩니다.
SELECT 문을 사용하여 시퀀스의 세부 정보를 가져오기 위해 이전 명령을 다시 실행하면 이 경우의 새로운 'last_value'가 ALTER 명령으로 지정한 값임을 확인할 수 있습니다.
무슨 일이 일어나는지 보기 위해 테이블에 새 항목을 삽입해 보겠습니다. 다음 이미지는 INSERT 쿼리와 SELECT 문을 실행한 후 얻는 결과를 보여줍니다. 새 항목의 'user_id'가 20으로 어떻게 설정되어 있는지 확인하세요. 우리가 만드는 모든 새 항목에는 마지막 값인 20을 기반으로 생성된 'user_id'가 있습니다.
다른 입력을 하면 'user_id'는 21이 되고 시퀀스는 동일한 논리를 사용하여 진행됩니다. 이것이 PostgreSQL에서 시퀀스를 재설정하는 방법입니다. 'reset' 명령은 기존 레코드에 영향을 주지 않습니다. 이는 시퀀스를 재설정한 후 작성하는 항목에 대한 새 시작 값만 정의합니다.
결론
PostgreSQL을 사용하면 기본 키 열에 정수 값을 자동 생성하는 방법이 있어 작업이 단순화됩니다. 기존 시퀀스가 있는 경우 ALTER SEQUENCE를 사용할 수 있습니다.
RESTART WITH 옵션과 함께 명령을 사용하여 재설정하려는 시퀀스와 시퀀스의 마지막 값으로 설정할 값을 지정합니다. 이렇게 하면 새 항목은 새로운 마지막 값을 기반으로 생성된 정수 값을 갖게 됩니다. PostgreSQL 시퀀스 재설정이 어떻게 작동하는지 이해하려면 제시된 예를 참조하세요.