DB2_自动生成值

DB2_自动生成值

生成数字序列的两种方法

在 DB2 中可以用两种方法自动生成一个数字序列:

 

IDENTITY 列

当用 IDENTITY 属性定义表的列时,每当将一行插入表时,就会自动为该列生成一个数值。

 

SEQUENCE 对象

让 DB2 自动生成数字序列的第二种方法是创建 SEQUENCE 对象。可以使用 序列表达式(sequence expression)来引用序列对象。序列表达式可以出现在表达式能够出现的大多数位置。序列表达式可以指定要返回的值是新生成的值还是以前生成的值。

在标识和序列之间做出选择

虽然标识和序列都用于生成数值,但您也许要根据特殊情况选择使用一种来代替另一种。

在以下情况下,标识列很有用:

  • 表中只有一列需要自动生成的值
  • 每一行都需要独立的值
  • 用自动生成器来产生表的主键
  • 生成新值的进程与对表的插入操作紧密联系,无论插入操作是如何发生的

在以下情况下,序列对象很有用:

  • 要将从一个序列生成的值存储到多个表中
  • 每个表有多个列需要自动生成的值(可能通过使用同一个序列或多个序列为每一行生成多个值)
  • 生成新值的进程与任何对表的引用无关

与序列对象不同,标识列是在表上定义的,因此需要某些限制。每个表最多只能有一个标识列。当创建一个列作为标识列时,对于该列必须使用确切的数字数据类型。因为标识属性为列生成一个值,这类似于 DEFAULT 子句所做的,所以在定义标识列时不能指定 DEFAULT 子句。标识列被隐式地定义成 NOT NULL

 1. 使用 IDENTITY 列创建订单表

 

CREATE TABLE customer_orders_t (
   order_id   
        INT NOT NULLGENERATED ALWAYS 
      AS IDENTITY 
      (START WITH 1 
       
        INCREMENT BY 1 
       
        MINVALUE 1 
       
        NO MAXVALUE 
       NO CYCLE
       NO CACHE
       ORDER),
   order_date 
        DATE NOT NULL,
   cust_id    
        INT NOT NULL,
   product_id 
        INT NOT NULL,
   quantity   
        INT NOT NULL,
   price      
        DECIMAL(10,2) 
        NOT NULL,
   status     
        CHAR(9) 
        NOT NULL,PRIMARY KEY (order_date, order_id));

INSERT INTO customer_orders_t 
        VALUES 
   (
        DEFAULT, CURRENT DATE,
    :cid, :pid, :qty, :cost, 'PENDING')

 

 2. SEQUENCE 对象

CREATE SEQUENCE orders_seq 
        AS INT
   
        START WITH 1 
   
        INCREMENT BY 1 
   
        MINVALUE 1 
   
        NO MAXVALUE 
   NO CYCLE
   NO CACHE
   ORDER;

=================
NEXT VALUE FOR orders_seq
=================
PREVIOUS VALUE FOR orders_seq

 http://www.ibm.com/developerworks/cn/data/library/techarticles/0302fielding/0302fielding.html

转载于:https://www.cnblogs.com/caroline4lc/p/4190156.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109611.html原文链接:https://javaforall.net

(0)
上一篇 2021年9月2日 下午11:00
下一篇 2021年9月2日 下午11:00


相关推荐

  • JavaWeb项目中遇到的关于request,require和session的知识点

    JavaWeb项目中遇到的关于request,require和session的知识点JavaWeb 项目中遇到的关于 request require 和 session 的知识点 1 request getParameter 和 request getAttribute 的区别一个比较好的讲解 https blog csdn net article details getParameter 和 getAttribute 最简单的两点区别就是赋值方式不一样 前者是客户端如浏览器端将请求参数值送给服务器端 而后者则是在请求到达服务器端之后 在服务器进行

    2026年3月17日
    2
  • office常用快捷键一览表_ppt居中对齐快捷键

    office常用快捷键一览表_ppt居中对齐快捷键今天给大家分享常用的office快捷键;快快收藏吧!

    2026年4月16日
    6
  • 斯坦福大学机器学习——EM算法求解高斯混合模型

    斯坦福大学机器学习——EM算法求解高斯混合模型EM算法(Expection-Maximizationalgorithm,EM)是一种迭代算法,通过E步和M步两大迭代步骤,每次迭代都使极大似然函数增加。但是,由于初始值的不同,可能会使似然函数陷入局部最优。下面来谈谈EM算法以及其在求解高斯混合模型中的作用。

    2022年6月28日
    33
  • mysql乐观锁实现

    mysql乐观锁实现各锁的概念 悲观锁 假定会发生并发冲突 屏蔽一切可能违反数据完整性的操作悲观锁 从字面理解就是很悲观 每次去拿数据的时候都认为别人会修改 所以在每次拿的时候对数据上锁 这样就保证了数据的准确性 比如 mysql 中的表锁 行锁 表锁 当你对一张表进行修改时 会锁死整张表 其他的请求需要在修改完成释放锁才能继续 在高并发的情景下不适用 行锁 当你对一张表的某一行数据修改时 会锁死这一行数

    2026年3月26日
    2
  • linux ioctl函数详解,ioctl函数详解「建议收藏」

    linux ioctl函数详解,ioctl函数详解「建议收藏」1.介绍Linux网络程序与内核交互的方法是通过ioctl来实现的,ioctl与网络协议栈进行交互,可得到网络接口的信息,网卡设备的映射属性和配置网络接口.并且还能够查看,修改,删除ARP高速缓存的信息,所以,我们有必要了解一下ioctl函数的具体实现.2.相关结构体与相关函数#includeintioctl(intd,intrequest,….);参数:d-文件描述符,这里是对网络套…

    2022年10月18日
    3
  • 和第三方接口对接总结

    和第三方接口对接总结接口对接分为两种形式:我方A公司提供接口给B公司,B公司进行一些操作时调用我们的接口进行实现。例:A开发会员等级同步接口,供B同步会员等级到B系统。B会员等级的变动需要调用A接口主动推送给A(即更新会员卡等级)。我们首先要做的就是按照对方的要求,在对方调用我们的接口,我方成功处理之后,按照对方所需要的返回数据以及格式反馈给他们信息。在写本接口中,因为我们会员卡等级的字段是不一样的,所…

    2022年5月2日
    54

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号