Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 자료구조
- 스프링부트
- 장고
- 개발
- django
- HTTP
- python3
- 파이썬
- JPA
- 보안
- mysql
- 디자인 패턴
- Python
- Spring
- db
- 파이썬3
- rabbitmq
- node.js
- bytecode
- BCI
- java
- 스프링 부트
- Spring Boot
- 데이터베이스
- 웹 개발
- 안드로이드
- 자바
- ORM
- 스프링
- 웹
Archives
- Today
- Total
semtax의 개발 일지
PostgreSQL에서 AUTO INCREMENT 사용하기 본문
반응형
개요
이번 문서에서는 mysql에 있는 AUTO INCREMENT와 유사한 기능을 PostgreSQL에서는 어떻게 사용하는지 알아 보도록 하겠다.
PostgreSQL Serial Type
PostgreSQL에서는 auto increment가 지원이 되는 Sequence 라는 타입을 지원하고 있다.
테이블 생성시 아래와 같이 SERIAL 키워드를 이용해서 컬럼의 타입을 정의함으로써, Sequence 타입을 사용 할 수 있다.
CREATE TABLE table_name(
id SERIAL
);
SERIAL 타입은 postgreSQL에서 지원하는 타입이므로, 내부적으로 실행될때는 아래와 같은 SQL로 바뀌게 된다.
CREATE SEQUENCE table_name_id_seq;
CREATE TABLE table_name (
id integer NOT NULL DEFAULT nextval('table_name_id_seq')
);
ALTER SEQUENCE table_name_id_seq
OWNED BY table_name.id;
보통 auto increment와 같은 기능은 primary key에 주로 사용되므로 보통 아래와 같은 방식으로 많이 사용이 된다.
CREATE TABLE fruits(
id SERIAL PRIMARY KEY,
name VARCHAR NOT NULL
);
데이터를 삽입할때는 2가지 방식으로 삽입이 가능하다.
INSERT INTO fruits(name) VALUES('Orange');
INSERT INTO fruits(id,name) VALUES(DEFAULT,'Apple');
PostgreSQL에서 SERIAL 타입은 아래 표와 같이 다양한 크기의 키 사이즈를 지원한다.
타입명 | 크기 | 범위 |
---|---|---|
SMALLSERIAL | 2 byte | 1 ~ 32,767 |
SERIAL | 4 byte | 1 ~ 2,147,483,647 |
BIGSERIAL | 8 byte | 1 ~ 9,223,372,036,854,775,807 |
반응형
'개발 > 데이터베이스' 카테고리의 다른 글
데이터베이스 DDL 자동 변환해주는 사이트 : SQLines (0) | 2020.06.07 |
---|---|
MySQL 아키텍처 Overview (0) | 2020.04.01 |
MySQL에서 SQL파일 실행하는 법 (0) | 2020.02.24 |
RDB에 트리구조 저장하기 (0) | 2020.02.23 |
맥 OS 에서 PostgreSQL 설치하기 (1) | 2020.01.11 |
Comments