Postgresql中新建表的时候,如何使用主键使用序列(sequence)的值进行自增长

 我们知道,一般的数据库中都有序列,可以使用它对主键进行自增长,hbm框架都是如此(比如,hibernate)。那么,在不使用hbm框架的情况下,如何使主键进行自增长呢。其实,很简单,只需要在建表的时候给主键加一个默认值即可,下面以postgresql数据库为例,给出一个简单的说明(其他数据库的语法也许跟这个不一样):

[SQL]  view plain  copy
  1. id integer NOT NULL DEFAULT nextval('personid_seq'::regclass)  

  

 上面的"nextval('personid_seq'::regclass"部分就是关键,其中,personid_seq 就是一个序列,可以通过下面的语句进行声明:

[SQL]  view plain  copy
  1. CREATE SEQUENCE personid_seq  
  2.   INCREMENT 1  
  3.   MINVALUE 1  
  4.   MAXVALUE 9223372036854775807  
  5.   START 1  
  6.   CACHE 5;  

 

这样一来,在往数据库插入记录的时候,就不必给id字段进行手动赋值了。

 

PS:需要注意的事,你在insert into的时候,需要指明字段,不然会报错的。比如,test表中共有id与name两个字段,其中,id使用如上方式进行了自增长,那么你在插入记录的时候,需要像下面这么来写SQL语句

[SQL]  view plain  copy
  1. insert into test(namevalues('tiger');  

 而不能写成下面这种的:

[SQL]  view plain  copy
  1. insert into test values('tiger');  

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值