예, 직렬 함수은 것과 같습니다.
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
매크로 수립하였습니다 시퀀스에만 테이블을 작성할 때 직렬 뿐이다. 직렬 관용으로충만하신 변경하십시오 기존 열 수 없습니다.
다른 모든 [정수 data type] 사용할 수 있습니다 (http://www.postgresql.org/docs/9.1/static/datatype-numeric.html # datatype int) ',' 같은 스몰린트.
예:
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;
사용하는 것이 아닌 자체 데이터 유형, 사용자 [직렬 데이터 유형] (http://www.postgresql.org/docs/9.1/static/datatype-numeric.html # 직렬 데이터 형식).
반면 it looks like 시퀀스에만 오른길로 MySQL auto_increment avamer 미묘한 하지만 몇 가지 중요한 차이가 있습니다.
오류가 있는 쿼리합니다 증분됩니다 직렬 열 받는다. 이로 인해 조각화가 쿼리합니다 충스러웠으니 실패했습니다. 아니라 행을 삭제. 예를 들어, 다음 쿼리합니다 실행하십시오 따라 PostgreSQL 데이터베이스.
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)
어떻게 1 부터 3 디이브이 uid 댁이라면 대신 1 ~ 2 개.
이 계속 발생할 경우 수동으로 직접 만들 조교하실 e0100042.log 호스트당:
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 를 설정할 수 있는 이 수동으로로 시뮬레이션하려면 4gbit/s " clash"; 나중에.
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);
It 실패하고 다음 오류 메시지:
>. 오류: 키 값을 고유 제약 " 복제본임을 위반하는 table1_pkey"; >. 자세한 정보: 키 (uid) = (5) 가 이미 있습니다.
Mysql 이 정상적으로 처리할 수 있는 것과 달리, 다음과 같이
INSERT INTO table1 (uid, col_b) VALUES(4, 4);
이제 다른 행일 삽입하십시오 uid 설정하지 않고
INSERT INTO table1 (col_b) VALUES(3);
+-----+-------+
| uid | col_b |
+-----+-------+
| 1 | 1 |
| 2 | 2 |
| 4 | 4 |
| 5 | 3 |
+-----+-------+
테스트 (x86_64) 및 PostgreSQL, MySQL 5.6.33 의 수행되었는지 linux*용 9.4.9
아이디 열이 SQL 표준의 정의에 따라, Postgres 시작으로 10 도 지원됩니다.
create table foo
(
id integer generated always as identity
);
insert into foo (id)
values (1);
그러나 이 심을 수 있습니다.
insert into foo (id) overriding system value
values (1);
이 같은 행동에 의해 생성된 옵션을 사용할 때 '기본' 있다 '는 근본적으로 기존 일련 의' 구축.
create table foo
(
id integer generated by default as identity
);
값을 수동으로 조정해야 할 때 제공되는 기본 조합으 수동으로로 아니라 함께 같은 직렬 '-' 얻어맞았다.
기본적으로 한 아이디 열이 없는 기본 키 (직렬 '처럼' 열). 해야 할 경우 1 차 키 제약 직접 정의할 필요가 있다.
죄송하지만 질문을 할 수 있는 첫 번째 스택 오버플로입니다 추진 좋았지만, 오래된 질문 / 답변 뛰어오름 up on Google.
이 게시물은 (에 먼저 다가와 있는 구글) 구문을 사용하여 이야기하고 더 업데이트되도록 PostgreSQL 용 10: https://blog.2ndquadrant.com/postgresql-10-identity-columns/
어떤 변화가 발생합니까 다음과 같이 쓸 수 있다.
CREATE TABLE test_new (
id int GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY,
);
희망을 주는:)
않도록 빈틈없어야 삽입하십시오 e0100042.log 필드, 그렇지 않으면 쓸 때 페일오버됩니다 e0100042.log 일련 또는 직접 전달된 삽입됨 가치:
-- 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, 만들기 '에 대한 의견을 묻는 질문 및 질문하시리니 의해 간접적으로 위의 예 - 직렬' 도왔으매 시퀀스에만 만듭니다.
CREATE TABLE foo (id SERIAL,bar varchar);
'테이블 만들기' '열' foo.id '' foo_id_seq 암시적으로 e0100042.log 만들기 위한 직렬 것이다. 이에 따라 직렬 ',' [4 바이트입니다] 는 특정 데이터 형식 단축시킵니다 id 사용 편의성을 위해 좋은 하는 경우를 제외하고.
이렇게 사용할 수 있도록 반드시 좋겠다.
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/