What's the PostgreMySQL AUTOINCREMENT와 동일한 SQL 데이터 유형?
로 입니다.SQL에서 Postgre로 전환 중입니다.과 저는 어떻게 SQL을 수 .INT
에 의칼이 표시됩니다.AUTO INCREMENT
Postgre는 Postgre서 보았다니습식형에. 문서에서 SQL이라는 .SERIAL
하지만 사용할 때 구문 오류가 발생합니다.
예, SERIAL은 동등한 기능입니다.
CREATE TABLE foo (
id SERIAL,
bar varchar
);
INSERT INTO foo (bar) VALUES ('blah');
INSERT INTO foo (bar) VALUES ('blah');
SELECT * FROM foo;
+----------+
| 1 | blah |
+----------+
| 2 | blah |
+----------+
SERIAL은 시퀀스 주위에 테이블 시간 매크로를 만들 뿐입니다.SERIAL을 기존 열로 변경할 수 없습니다.
다음과 같은 다른 정수 데이터 유형을 사용할 수 있습니다.smallint
.
예:
CREATE SEQUENCE user_id_seq;
CREATE TABLE user (
user_id smallint NOT NULL DEFAULT nextval('user_id_seq')
);
ALTER SEQUENCE user_id_seq OWNED BY user.user_id;
사용자 직렬 데이터 유형보다는 사용자 고유의 데이터 유형을 사용하는 것이 좋습니다.
이미 존재하는 테이블의 id에 시퀀스를 추가하려면 다음을 사용할 수 있습니다.
CREATE SEQUENCE user_id_seq;
ALTER TABLE user ALTER user_id SET DEFAULT NEXTVAL('user_id_seq');
Postgres 10부터는 SQL 표준에 정의된 ID 열도 지원됩니다.
create table foo
(
id integer generated always as identity
);
명시적으로 요청하지 않는 한 재정의할 수 없는 ID 열을 만듭니다. 삽입은 실패하고 됩니다.generated always
:
insert into foo (id)
values (1);
그러나 이는 무시될 수 있습니다.
insert into foo (id) overriding system value
values (1);
을 generated by default
이것은 본질적으로 기존과 동일한 행동입니다.serial
구현:
create table foo
(
id integer generated by default as identity
);
값을 . - 값 을 수 동 시 수 조 로 야 해 합 정 니 다 으 동 도 스 퀀 기 본 우 경 제 으 로 는 하 공 ▁needs ▁as ▁when ▁manually ▁a ▁the ▁same 다 ▁as ▁with ▁adjusted ▁is 합 ▁the ▁- ▁to , ▁manually 니 ▁well ▁supplied ▁be 이는 다음과 같습니다.serial
기둥.
은열 예아다니닙키가기본예(▁a:▁like다:serial
열). 키 .하나여야 하는 경우 기본 키 제약 조건을 수동으로 정의해야 합니다.
시퀀스가 MySQL auto_increment와 동일한 것처럼 보이지만 몇 가지 미묘하지만 중요한 차이점이 있습니다.
실패한 쿼리는 시퀀스/일련 증분
직렬 열은 실패한 쿼리에서 증가합니다.이로 인해 행 삭제뿐만 아니라 실패한 쿼리에서 조각화가 발생합니다.예를 들어 Postgre에서 다음 쿼리를 실행합니다.SQL 데이터베이스:
CREATE TABLE table1 (
uid serial NOT NULL PRIMARY KEY,
col_b integer NOT NULL,
CHECK (col_b>=0)
);
INSERT INTO table1 (col_b) VALUES(1);
INSERT INTO table1 (col_b) VALUES(-1);
INSERT INTO table1 (col_b) VALUES(2);
SELECT * FROM table1;
다음과 같은 출력이 표시됩니다.
uid | col_b
-----+-------
1 | 1
3 | 2
(2 rows)
uid가 1에서 2가 아닌 1에서 3으로 어떻게 이동하는지 주목하세요.
이 문제는 다음을 사용하여 직접 시퀀스를 수동으로 생성한 경우에도 발생합니다.
CREATE SEQUENCE table1_seq;
CREATE TABLE table1 (
col_a smallint NOT NULL DEFAULT nextval('table1_seq'),
col_b integer NOT NULL,
CHECK (col_b>=0)
);
ALTER SEQUENCE table1_seq OWNED BY table1.col_a;
MySQL이 어떻게 다른지 테스트하려면 MySQL 데이터베이스에서 다음을 실행합니다.
CREATE TABLE table1 (
uid int unsigned NOT NULL AUTO_INCREMENT PRIMARY KEY,
col_b int unsigned NOT NULL
);
INSERT INTO table1 (col_b) VALUES(1);
INSERT INTO table1 (col_b) VALUES(-1);
INSERT INTO table1 (col_b) VALUES(2);
단편화하지 않고 다음을 확인해야 합니다.
+-----+-------+
| uid | col_b |
+-----+-------+
| 1 | 1 |
| 2 | 2 |
+-----+-------+
2 rows in set (0.00 sec)
직렬 열 값을 수동으로 설정하면 이후 쿼리가 실패할 수 있습니다.
이것은 @trev가 이전 답변에서 지적한 것입니다.
이를 시뮬레이션하려면 수동으로 UID를 4로 설정하고 나중에 "충돌"합니다.
INSERT INTO table1 (uid, col_b) VALUES(5, 5);
표 데이터:
uid | col_b
-----+-------
1 | 1
3 | 2
5 | 5
(3 rows)
다른 삽입을 실행합니다.
INSERT INTO table1 (col_b) VALUES(6);
표 데이터:
uid | col_b
-----+-------
1 | 1
3 | 2
5 | 5
4 | 6
다른 삽입을 실행하면 다음과 같습니다.
INSERT INTO table1 (col_b) VALUES(7);
다음 오류 메시지와 함께 실패합니다.
오류: 중복 키 값이 고유 제약 조건 "table1_pkey"을(를) 위반합니다. 상세 내역:키(uid)=(5)가 이미 있습니다.
이와 대조적으로 MySQL은 다음과 같이 이 문제를 정상적으로 처리합니다.
INSERT INTO table1 (uid, col_b) VALUES(4, 4);
이제 uid를 설정하지 않고 다른 행을 삽입합니다.
INSERT INTO table1 (col_b) VALUES(3);
쿼리가 실패하지 않고 uid가 5로 점프합니다.
+-----+-------+
| uid | col_b |
+-----+-------+
| 1 | 1 |
| 2 | 2 |
| 4 | 4 |
| 5 | 3 |
+-----+-------+
테스트는 MySQL 5.6.33에서 Linux(x86_64) 및 Postgre용으로 수행되었습니다.SQL 9.4.9
죄송합니다. 이전 질문을 다시 요약하자면, Google에서 처음으로 나타나는 스택 오버플로 질문/답변입니다.
이 게시물(Google에서 먼저 올라온 글)은 Postgre에 대해 더 업데이트된 구문을 사용하는 것에 대해 설명합니다.SQL 10: https://blog.2ndquadrant.com/postgresql-10-identity-columns/
그것은 다음과 같습니다.
CREATE TABLE test_new (
id int GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY,
);
도움이 되길 바랍니다 :)
시리얼 또는 시퀀스 필드에 직접 삽입하지 않도록 주의해야 합니다. 그렇지 않으면 시퀀스가 삽입된 값에 도달하면 쓰기가 실패합니다.
-- Table: "test"
-- DROP TABLE test;
CREATE TABLE test
(
"ID" SERIAL,
"Rank" integer NOT NULL,
"GermanHeadword" "text" [] NOT NULL,
"PartOfSpeech" "text" NOT NULL,
"ExampleSentence" "text" NOT NULL,
"EnglishGloss" "text"[] NOT NULL,
CONSTRAINT "PKey" PRIMARY KEY ("ID", "Rank")
)
WITH (
OIDS=FALSE
);
-- ALTER TABLE test OWNER TO postgres;
INSERT INTO test("Rank", "GermanHeadword", "PartOfSpeech", "ExampleSentence", "EnglishGloss")
VALUES (1, '{"der", "die", "das", "den", "dem", "des"}', 'art', 'Der Mann küsst die Frau und das Kind schaut zu', '{"the", "of the" }');
INSERT INTO test("ID", "Rank", "GermanHeadword", "PartOfSpeech", "ExampleSentence", "EnglishGloss")
VALUES (2, 1, '{"der", "die", "das"}', 'pron', 'Das ist mein Fahrrad', '{"that", "those"}');
INSERT INTO test("Rank", "GermanHeadword", "PartOfSpeech", "ExampleSentence", "EnglishGloss")
VALUES (1, '{"der", "die", "das"}', 'pron', 'Die Frau, die nebenen wohnt, heißt Renate', '{"that", "who"}');
SELECT * from test;
질문의 맥락에서 그리고 @sereja1c의 의견에 대한 답변으로, 생성.SERIAL
암시적으로 시퀀스를 생성하므로 위의 예에서 -
CREATE TABLE foo (id SERIAL,bar varchar);
CREATE TABLE
암시적으로 시퀀스를 생성합니다.foo_id_seq
연속 칼럼용foo.id
.이런 이유로,SERIAL
[4Bytes]는 ID에 대한 특정 데이터 유형이 필요하지 않은 경우 사용하기 쉽기 때문에 좋습니다.
포스트그레 이후SQL 10
CREATE TABLE test_new (
id int GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY,
payload text
);
이 방법은 확실히 효과가 있을 것입니다. 다음과 같은 도움이 되기를 바랍니다.
CREATE TABLE fruits(
id SERIAL PRIMARY KEY,
name VARCHAR NOT NULL
);
INSERT INTO fruits(id,name) VALUES(DEFAULT,'apple');
or
INSERT INTO fruits VALUES(DEFAULT,'apple');
자세한 내용은 다음 링크에서 확인할 수 있습니다. http://www.postgresqltutorial.com/postgresql-serial/
시퀀스를 만듭니다.
CREATE SEQUENCE user_role_id_seq
INCREMENT 1
MINVALUE 1
MAXVALUE 9223372036854775807
START 3
CACHE 1;
ALTER TABLE user_role_id_seq
OWNER TO postgres;
그리고 테이블을 변경
ALTER TABLE user_roles ALTER COLUMN user_role_id SET DEFAULT nextval('user_role_id_seq'::regclass);
언급URL : https://stackoverflow.com/questions/787722/whats-the-postgresql-datatype-equivalent-to-mysql-auto-increment
'programing' 카테고리의 다른 글
추가 업데이트:다음 추적되지 않은 작업 트리 파일은 병합할 때 덮어씁니다. (0) | 2023.05.31 |
---|---|
@ViewChild와 @ContentChild의 차이점은 무엇입니까? (0) | 2023.05.31 |
트랜잭션 관리자가 원격/네트워크 트랜잭션에 대한 지원을 사용하지 않도록 설정했습니다. (0) | 2023.05.26 |
동적 SQL - EXEC(@SQL) 대 EXEC SP_EXECUTSQL(@SQL) (0) | 2023.05.26 |
Mongoose 문서를 일반 객체로 변환하려면 어떻게 해야 합니까? (0) | 2023.05.26 |