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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java是什么?Java到底能干嘛?

    Java是什么?Java到底能干嘛?我刚开始学习Java的时候,很长一段时间都有这么个疑惑?Java到底是啥?它能干什么?自己也看过不少的课程和书,大部分都是从Java的发展史开始讲,总之就是那些什么Jav…

    2022年7月7日
    18
  • aop 实现原理_简述aop的原理

    aop 实现原理_简述aop的原理概述:最近在开发中遇到了一个刚好可以用AOP实现的例子,就顺便研究了AOP的实现原理,把学习到的东西进行一个总结。文章中用到的编程语言为kotlin,需要的可以在IDEA中直接转为java。这篇文章将会按照如下目录展开:AOP简介 代码中实现举例 AOP实现原理 部分源码解析1.AOP简介相信大家或多或少的了解过AOP,都知道它是面向切面编程,在网上搜索可以找到很多的解释。…

    2022年9月18日
    1
  • synchronized偏向锁和轻量级锁_偏向锁/轻量级锁/重量级锁的原理

    synchronized偏向锁和轻量级锁_偏向锁/轻量级锁/重量级锁的原理今天简单了解了一下java轻量级锁和重量级锁以及偏向锁。看了看这篇文章觉得写的不错原文链接java 偏向锁、轻量级锁及重量级锁synchronized原理Java对象头与Monitorjava对象头是实现synchronized的锁对象的基础,synchronized使用的锁对象是存储在Java对象头里的。对象头包含两部分:Mark Word 和 Class Metadata Address其中Mark Word在默认情况下存储着对象的HashCode、分代年龄、锁标记位等以下是32位JVM的

    2022年8月9日
    9
  • ubuntu 出现GPG Error的问题[通俗易懂]

    ubuntu 出现GPG Error的问题[通俗易懂]ubuntu系统sudoapt-getupdate错误提示:gpgerrorthepublickeyisnotavailableno_pubkey5523BF*********在我们系统上无法获取publickey,所以需要导入该publickey 解决办法:sudoapt-keyadv–keyserverkeys

    2022年10月13日
    3
  • Arduino文档阅读笔记-RFID工作原理及RC522模块介绍

    RFID工作原理RFID(RadioFrequencyIdentification):无线射频识别RFID由2个部分组成:应答器/标签被贴在某个物体上的东东。无线接收器用于读取应答器/标签上的数据。读卡器由频射模块及高平磁场组成。Tag/应答器为待感应设备,此设备不包含电池。他只包含微型集成电路芯片及存储数据的介质以及接收和发送信号的天线。读取tag中的数据,首先要放…

    2022年4月8日
    86
  • Laravel数据库操作的三种方式

    Laravel数据库操作的三种方式

    2021年10月26日
    39

发表回复

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

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