oracle序列的創建和使用

来源:https://www.cnblogs.com/Stir-friedEggplant/archive/2018/01/08/8243437.html
-Advertisement-
Play Games

oracle 序列的創建與使用 (2012-03-15 16:14:09) 轉載 oracle 序列的創建與使用 轉載 在Oracle中,可以使用序列自動生成一個整數序列,主要用來自動為表中的數據類型的主鍵列提供有序的唯一值,這樣就可以避免在向表中添加數據時,手工指定主鍵值。而且使用手工指定主鍵值這 ...


oracle 序列的創建與使用

 (2012-03-15 16:14:09) ---------------------------------------------------------------------------------------------------轉載-------------------------------------------------------------------------------------------------------------------

    在Oracle中,可以使用序列自動生成一個整數序列,主要用來自動為表中的數據類型的主鍵列提供有序的唯一值,這樣就可以避免在向表中添加數據時,手工指定主鍵值。而且使用手工指定主鍵值這種方式時,由於主鍵值不允許重覆,因此它要求操作人員在指定主鍵值時自己判斷新添加的值是否已經存在,這很顯然是不可取的。

(1)創建序列

序列與視圖一樣,並不占用實際的存儲空間,只是在數據字典中保存它的定義信息。創建序列需要使用CREATE SEQUENCE語句,其語法如下:

CREATE SEQUENCE [schema]。sequence_name  --序列名

[ START WITH start_number ]  --開始數字

[ INCREMENT BY increment_number ]  --每次加幾

[ MINVALUE minvalue | NOMINVALUE ]  --最小值

[ MAXVALUE maxvalue | NOMAXVALUE ]  --最大值

[ CACHE cache_number | NOCACHE ]  

[ CYCLE | NOCYCLE ]  --是否迴圈

[ ORDER | NOORDER ];  

註意:cache參數指定記憶體預分配的序列數的個數,預設20個,為了加快訪問速度。

      order參數指定是否按照請求次序生成序列號,一般使用序列生成主鍵值時,影響不大。

(2)序列中的兩個偽列

Currval:用於獲取序列的當前值,必須再使用nextval一次之後才能使用。 nextval:用於獲取序列的下一個值,第一次使用返回的是初始值,向表中的主鍵賦值的時候使用此偽列。 (3)序列舉例 
  • 首先創建student表:
    create table student(     sid number(4) primary key,     sname varchar2(8) not null     );
  • 創建student_seq序

    create sequence student_seq

    start with 1

    increment by 1

    nocache nocycle order;

  • 創建觸發器(使用student_seq序列)

 

 

     create trigger tr_student

    before insert on student

    for each row

    begin

    select student_seq into :new.sid from dual;

    end;

  • 插入數據:

    SQL> insert into student(sname) values('zhang')

    已創建 1 行。

    SQL> insert into student(sname) values('li');

    已創建 1 行。

    SQL> insert into student(sname) values('wang')

    已創建 1 行。

  • 查詢數據:
  • SQL> select * from student;
  •        SID SNAME
    ---------- --------
            1  zhang
            2  li
            3  wang

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 和關係資料庫一樣,Neo4j同樣可以創建索引來加快查找速度。 在關係資料庫中創建索引需要索引欄位和指向記錄的指針,通過索引可以快速查找到表中的行。 在Neo4j中,其索引是通過屬性來創建,便於快速查找節點或者關係。 手動索引 先來說一下怎樣創建手動索引。 創建索引採用顯示創建,就像添加節點一樣添加索 ...
  • 1.Hive安裝與配置 Hive官網:https://hive.apache.org/ 1. 安裝文件下載 從Apache官網下載安裝文件 http://mirror.bit.edu.cn/apache/hive/ (apache-hive-2.3.2-bin.tar.gz) 還有我選擇mysql作 ...
  • 本文主要介紹mysql 5.5在centos 6.5系統上的安裝步驟。 ...
  • 本文主要介紹資料庫Redis在CentOS 6.5和Mac上的安裝步驟。 ...
  • 首先明白一點並不是mysql禁止遠程連接,而是MYSQL的賬號禁止遠程連接。可能覺得我有點咬文嚼字了,不過我感覺分清這點還是很重要的。預設情況下,所有賬號都是禁止遠程連接的。在安裝MYSQL的時候,在設置ROOT密碼那裡有一個CHECKBOX,選中的話就開啟了ROOT的遠程登陸功能,預設是沒被選中的 ...
  • 概述 SQL Server Service Broker 用來創建用於交換消息的會話。消息在目標和發起方這兩個端點之間進行交換。消息用於傳輸數據和觸發消息收到時的處理過程。目標和發起方既可以在同一資料庫引擎實例的同一資料庫或不同資料庫中,也可以在不同資料庫引擎實例的同一資料庫或不同資料庫中。 每個 ...
  • 大數據簡介 大數據的概念 Volume(數據容量)、Variety(數據類型)、Viscosity(價值密度)、Velocity(速度)、Veracity(真實性) 大數據的性質 非結構性、不完備性、時效性、安全性、可靠性 大數據處理的全過程 數據採集與記錄 --> 數據抽取、清洗、標記 --> 數 ...
  • RHEL6+oracle11.2 無界面化命令安裝如下: 1.所需安裝軟體包檢查: yum install binutils-2.* compat-libcap1* compat-libstdc++-33-* gcc-4.* gcc-c++-4.* glibc-2.* glibc-devel-2.* ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...