PostgreSQL SERIAL创建自增列

  本文我们介绍PostgreSQL SERIAL,并展示如何使用serial类型创建表自增列。

  PostgreSQL SERIAL伪类型

  PostgreSQL序列是一种特殊的用于生产整数序列数据库对象。序列通常用于主键列,与mysql的AUTO_INCREMENT 概念类似。创建表时使用serial伪类型定义序列:

  CREATE TABLE table_name(

  id SERIAL

  );

  赋值serial伪类型给id列,PostgreSQL将执行下列步骤:

  创建序列对象并设置下一个生成值作为列的缺省值。

  给对应列增加NOT NULL约束,因为序列总是生成一个整数值,不能为null值。

  赋值序列的拥有者给id列,因此当id列或表被删除时,序列对象自动被删除。

  对应背后执行语句:

  CREATE TABLE table_name(

  id SERIAL

  );

  相当于执行了下面语句:

  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;

  PostgreSQL 提供三种序列伪类型,分别为SMALLSERIAL, SERIAL, BIGSERIAL,对应范围如下:

  Name  Storage Size  Range

  SMALLSERIAL  2 bytes  1 to 32,767

  SERIAL  4 bytes  1 to 2,147,483,647

  BIGSERIAL  8 bytes  1 to 922,337,2036,854,775,807

  PostgresQL SERIAL示例

  特别需要注意的是,serial列不会隐式在列上创建索引或是该列为主键列。当然可以很容易使用PRIMARY KEY关键字增加相应约束。

  下面语句创建fruits表,其中id类是serial类型:

  CREATE TABLE fruits(

  id SERIAL PRIMARY KEY,

  name VARCHAR NOT NULL

  );

  在insert语句中,可以忽略对应列或使用default关键字都可以给serial赋值,请看示例:

  INSERT INTO fruits(name) VALUES('orange');

  或者: 无锡人流医院 http://www.bhnfkyy.com/

  INSERT INTO fruits(id,name) VALUES(DEFAULT,'apple');

  PostgreSQL 给fruits表中插入两行记录,id的值为1和2:

  SELECT *

  FROM fruits;

  id | name

  ----+--------

  1 | apple

  2 | orange

  (2 rows)

  使用pg_get_serial_sequence函数可以获得serial列的序列名称:

  pg_get_serial_sequence('table_name','column_name')

  通过给currval函数传入序列名称可以获得当前生成的值。举例,下面语句返回最近生成的值:

  SELECT currval(pg_get_serial_sequence('fruits', 'id'));

  返回结果:

  currval

  ---------

  2

  (1 row)

  当执行insert语句是,你想获得序列生成的值,可以在insert语句中使用RETURNING id子句实现。下面语句插入一行新的记录,并返回id列生成的值:

  INSERT INTO fruits(name) VALUES('banana')

  RETURNING id;

  结果如下:

  id

  ----

  3

  (1 row)

  序列生成器不是事务安全的。意味着如果两个并发数据库连接尝试从序列中获取下一个值,每个客户端获得不同的值。如果一个客户端回滚事务,则该序列值将被弃用,导致序列值不连续。

PostgreSQL SERIAL创建自增列的更多相关文章

  1. postgres serial创建自增列

    Sequence是数据库中一类特殊的对象,其用于生成唯一数字标识符.一个典型的应用场景就是手动生成一系列主键.Sequence和MySQL中的AUTO_INCREMENT的概念很像. 创建序列Sequ ...

  2. Oracle12c:支持通过创建identity columen来实现创建自增列

    oracle12c之前如果需要创建自增列必须要通过sequence+trigger来实现.但是oracle12c已经可以像mysql,sqlserver一样通过identity column来设置自增 ...

  3. 【postgresql】创建自增SEQUENCE

    CREATE SEQUENCE circlefence_id_seq START WITH 1 INCREMENT BY 1 NO MINVALUE NO MAXVALUE CACHE 1; alte ...

  4. c# Mongodb创建自增列

    MongoCollection<BsonDocument> tblCount; if (!db.CollectionExists(tblCountName))            {   ...

  5. Oracle自增列创建方法

    最近在做Oracle的项目,由于以前没有接触过Oracle的开发,遇到了不少的问题,比如给Oracle表添加自增列,与SQL Server就不同. Oracle没有自增字段这样的功能,但是通过触发器( ...

  6. oracle入坑日记<六>自增列创建和清除(含序列和触发器的基础用法)

    0   前言 用过 SQLserver 和 MySQL 的自增列(auto_increment),然而 Oracle 在建表设置列时却没有自增列. 查阅资料后发现 Oracle 的自增列需要手动编写. ...

  7. sqlite3创建自增主键,以及清空表使自增列归零

    1.创建自增主键 CREATE TABLE tb_python (ID INTEGER PRIMARY KEY AUTOINCREMENT,TITLE TEXT,URL TEXT); 2.清空表 SQ ...

  8. SQL Server 2008 R2——使用计算列为表创建自定义的自增列

    =================================版权声明================================= 版权声明:原创文章 谢绝转载  请通过右侧公告中的“联系邮 ...

  9. mssql 获取自增列起始及增量

    --首先创建一个表 CREATE TABLE [dbo].[abcd]( ,) NOT NULL, ) NULL, ) NULL ) ON [PRIMARY] --获取起始值 SELECT IDENT ...

随机推荐

  1. axios post 400 状态码

    1.400状态码 400的主要有两种形式: (1).bad request意思是“错误的请求": (2).invalid hostname意思是"不存在的域名”.   2.axio ...

  2. 单细胞ENS发育数据库

    iSyTE 2.0: a database for expression-based gene discovery in the eye - 眼睛发育 StemMapper: a curated ge ...

  3. Aspect切面的使用实例

    一.导入切面库 以maven工程为例,除了springmvc基础的库,需要导入切面库,本例aspectj为例. <properties> <aspectj.version>&l ...

  4. wamp64显示黄色图标不能忍

    哎,昨天硬盘合区了下,重新安装了wamp64,删库的时候忘记备份数据库,灾难啊,只能自己重新建库建表了,深刻的教训啊. 然后还启动后是黄色图标,不能忍啊,发现wamp64需要启动三个服务,mysql, ...

  5. mac的brew安装tomcat以及idea设置

    Tomcat安装 brew search tomat 有tomcat@7. tomcat@8. tomcat最新版本(即tomcat9)三个版本 brew install tomcat 启动tomca ...

  6. [资料]ObjectARX 2020参考指南翻译中文版

    chm使用Google Chrome浏览器翻译,有些翻译不是很理想,因为2万5千多个html文件, 修正难度太大,所以只处理了一部分. 非常感谢 gzxl 辛苦肉眼修正一些翻译问题. 欢迎进入QQ群: ...

  7. tween算法

    tween算法 https://www.cnblogs.com/cloudgamer/archive/2009/01/06/Tween.html 参数说明: t: current time:当前时间: ...

  8. laravel 配置自动加载多路由文件

    在 app\Providers\RouteServiceProvider文件下增加方法&注册: 增加之后就可以在routers下建立api文件夹,在里面添加路由了

  9. flask,scrapy,django信号

    简介 Django.Flask.scrapy都包含了一个“信号分配器”,使得当一些动作在框架的其他地方发生的时候,解耦的应用可以得到提醒. 通俗来讲,就是一些动作发生的时候,信号允许特定的发送者去提醒 ...

  10. 使用WinFrom + CefSharp 开发客户端程序

    今天使用CefSharp,加上本地资源文件嵌入了HTML.CSS.JS文件,做为Winform的UI:效果不错,漂亮可控,简简单单,半天时间搞定从开发到上线: 下面记录下相关的备忘: (窗口的效果) ...