Postgresql 创建主键并设置自动递增的三种方法
来源:互联网 发布:linux jdk1.7下载地址 编辑:程序博客网 时间:2024/06/05 11:12
Postgresql 创建主键并设置自动递增的三种方法
2011-02-17 13:50:35| 分类: Postgres基础
from http://francs3.blog.163.com/blog/static/40576727201111715035318/ Postgresql 有以下三种方法设置主键递增的方式,下面来看下相同点和不同点。
--方法一
create table test_a
(
id serial,
name character varying(128),
constraint pk_test_a_id primary key( id)
);
NOTICE: CREATE TABLE will create implicit sequence "test_a_id_seq" for serial column "test_a.id"
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "pk_test_a_id" for table "test_a"
CREATE TABLE
--方法二
create table test_b
(
id serial PRIMARY KEY,
name character varying(128)
);
NOTICE: CREATE TABLE will create implicit sequence "test_b_id_seq" for serial column "test_b.id"
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "test_b_pkey" for table "test_b"
CREATE TABLE
--方法三
create table test_c
(
id integer PRIMARY KEY,
name character varying(128)
);
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "test_c_pkey" for table "test_c"
CREATE TABLE
CREATE SEQUENCE test_c_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
alter table test_c alter column id set default nextval('test_c_id_seq');
很明显从上面可以看出,方法一和方法二只是写法不同,实质上主键都通过使用 serial 类型来实现的,
使用serial类型,PG会自动创建一个序列给主键用,当插入表数据时如果不指定ID,则ID会默认使用序列的
NEXT值。
方法三是先创建一张表,再创建一个序列,然后将表主键ID的默认值设置成这个序列的NEXT值。这种写法
似乎更符合人们的思维习惯,也便于管理,如果系统遇到sequence 性能问题时,便于调整 sequence 属性;
--比较三个表的表结构
skytf=> \d test_a
Table "skytf.test_a"
Column | Type | Modifiers
--------+------------------------+-----------------------------------------------------
id | integer | not null default nextval('test_a_id_seq'::regclass)
name | character varying(128) |
Indexes:
"pk_test_a_id" PRIMARY KEY, btree (id)
skytf=> \d test_b
Table "skytf.test_b"
Column | Type | Modifiers
--------+------------------------+-----------------------------------------------------
id | integer | not null default nextval('test_b_id_seq'::regclass)
name | character varying(128) |
Indexes:
"test_b_pkey" PRIMARY KEY, btree (id)
skytf=> \d test_c
Table "skytf.test_c"
Column | Type | Modifiers
--------+------------------------+-----------------------------------------------------
id | integer | not null default nextval('test_c_id_seq'::regclass)
name | character varying(128) |
Indexes:
"test_c_pkey" PRIMARY KEY, btree (id)
从上面可以看出,三个表表结构一模一样, 三种方法如果要寻找差别,可能仅有以下一点,
当 drop 表时,方法一和方法二会自动地将序列也 drop 掉, 而方法三不会
- Postgresql 创建主键并设置自动递增的三种方法
- Postgresql 创建主键并设置自动递增的三种方法
- Postgresql 创建主键并设置自动递增的三种方法
- Postgresql 创建主键并设置自动递增的三种方法
- oracle 怎样设置自动递增的的字段,也就是设置自动递增的ID 主键
- postgreSQL怎样创建一个序列号/自动递增的字段
- Oracle||PL/SQL 设置主键自动递增
- PL/SQL如何设置主键自动递增
- 三种获得自动生成主键的方法
- mybatis+postgresql返回递增主键的正确姿势及勘误
- 设置mysql递增主键的起始值
- ORACLE设置递增主键
- 设置(创建)主键和外键的三种方式 和 删除含有主键外键的表顺序
- SqlServer代码设置主键并自动生长
- PowerDesigner设置MYSQL主键自动增长的方法
- PowerDesigner设置MYSQL主键自动增长的方法
- PowerDesigner设置MYSQL主键自动增长的方法
- oracle主键自动递增设计
- 使用JNI进行混合编程:在C/C++中调用Java代码
- MFC组件应用
- Android Dependencies
- 用标准的SQL语句实现查询记录的分页
- Android国际化(一)语言、国家/区域代码
- Postgresql 创建主键并设置自动递增的三种方法
- JNI和NDK使用介绍
- SQL Server返回最后一个标识值的三个函数:IDENT_CURRENT、@@IDENTITY、SCOPE_IDENTITY
- Android打印代码调用栈
- 数据库出现ORA-01033问题 解决方法
- 开发自己的Maven插件之四:基本概念
- Objective-C中的一些特殊的数据类型
- Amazon Flow更新 支持QR条码及增强现实购物功能
- android2.3修改ethernet默认为不选中状态