PostgreSQL에서 시퀀스를 재설정하는 방법

Postgresqleseo Sikwonseuleul Jaeseoljeonghaneun Bangbeob



PostgreSQL 시퀀스를 사용하는 것은 특히 기본 키의 경우 자동 증가 값을 사용하는 효과적인 방법입니다. 시작 값이 정의되지 않은 경우 INT의 자동 증가는 0에서 시작됩니다. 그러나 자동 증가 열에서 시퀀스에 사용할 시작 값을 지정할 수 있습니다.

또한 시퀀스의 다음 값을 변경해야 하는 상황이 발생하는 경우 시퀀스를 신속하게 재설정하고 테이블의 다음 항목에 대해 시작할 값을 지정할 수 있습니다. 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 시퀀스 재설정이 어떻게 작동하는지 이해하려면 제시된 예를 참조하세요.