Oralce 序列

来源:http://www.cnblogs.com/qianyuliang/archive/2017/11/08/7804006.html
-Advertisement-
Play Games

序列: 是oacle提供的用於產生一系列唯一數字的資料庫對象。 l 自動提供唯一的數值 l 共用對象 l 主要用於提供主鍵值 l 將序列值裝入記憶體可以提高訪問效率 創建序列: 1、 要有創建序列的許可權 create sequence 或 create any sequence 2、 創建序列的語法 ...


序列: 是oacle提供的用於產生一系列唯一數字的資料庫對象。
l  自動提供唯一的數值
l  共用對象
l  主要用於提供主鍵值
l  將序列值裝入記憶體可以提高訪問效率

創建序列:
1、  要有創建序列的許可權 create sequence 或 create any sequence
2、  創建序列的語法

CREATE SEQUENCE sequence  //創建序列名稱
       [INCREMENT BY n]  //遞增的序列值是n 如果n是正數就遞增,如果是負數就遞減 預設是1
       [START WITH n]    //開始的值,遞增預設是minvalue 遞減是maxvalue
       [{MAXVALUE n | NOMAXVALUE}] //最大值
       [{MINVALUE n | NOMINVALUE}] //最小值
       [{CYCLE | NOCYCLE}] //迴圈/不迴圈
       [{CACHE n | NOCACHE}];//分配並存入到記憶體中
 
  NEXTVAL 返回序列中下一個有效的值,任何用戶都可以引用
  CURRVAL 中存放序列的當前值
  NEXTVAL 應在 CURRVAL 之前指定 ,二者應同時有效

 

Create sequence seqEmp increment by 1 start with 1 maxvalue 3 minvalue 1
Cycle cache 2;
//先nextval 後 currval
Select seqEmp.nextval  from dual; 
Select seqEmp.currval  from dual;
Cache<max-min/increment


//解釋
{
Create 創建
Sequence 序列 seqEmop 序列名稱
Increment by 步長
Stat with 1 開始值
Maxvalue  最大值
Minvalue  最小值
 
Cycle 迴圈 nocycle 不迴圈
Cache 緩存   Cache<maxvalue-minvalue/increment by//一般不採用緩存
Nextvalue 下一個
Currval 當前值
 
}

 

//實例應用
//實現id的自動遞增
//第一步
CREATE TABLE members(
mid number(6),
name varchar2(30),
constraint pk_mid primary key(mid)
);
 
Create sequence seq_members
Increment by 1
Start with 1
Maxvalue 999999
Minvalue 1
Nocycle
nocache
 
insert into members values(seq_members.nextval,'qianyuliang');
commit;
select * from members;


/使用序列
會產生裂縫
    序列在下列情況下出現裂縫:
    回滾
    系統異常
>多個表同時使用同一序列

查看序列
 SELECT * FROM USER_SEQUENCES;
SELECT * FROM ALL_SEQUENCES;
SELECT * FROM DBA_SEQUENCES; //修改序列的增量, 最大值, 最小值, 迴圈選項, 或是否裝入記憶體 alter SEQUENCE sequence //創建序列名稱 [INCREMENT BY n] //遞增的序列值是n 如果n是正數就遞增,如果是負數就遞減 預設是1 [START WITH n] //開始的值,遞增預設是minvalue 遞減是maxvalue [{MAXVALUE n | NOMAXVALUE}] //最大值 [{MINVALUE n | NOMINVALUE}] //最小值 [{CYCLE | NOCYCLE}] //迴圈/不迴圈 [{CACHE n | NOCACHE}];//分配並存入到記憶體中 修改序列的註意事項: 必須是序列的擁有者或對序列有 ALTER 許可權 只有將來的序列值會被改變 改變序列的初始值只能通過刪除序列之後重建序列的方法實現 刪除序列 使用DROP SEQUENCE 語句刪除序列 刪除之後,序列不能再次被引用 Alter sequence seq_members maxvalue 5; Select seq_members.nextval from dual;

 


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

-Advertisement-
Play Games
更多相關文章
  • 重設密碼的方法: 具體方法是: 1.先在安裝目錄找到my.ini配置文件,打開配置文件, 找到[mysqld]一行,在下麵添加skip-grant-tables後保存該文件 重新啟mysql動服務; 2.然後在mysql的cmdline執行mysql -u root mysql, mysql>use ...
  • 參考文檔: 本文簡單介紹memcached伺服器端的安裝配置,與php-memcache客戶端連接伺服器端的配置與操作。 一.簡介 1. 簡介 Memcached是一款開源、高性能、分散式記憶體對象緩存系統,可應用各種需要緩存的場景,其主要目的是通過降低對Database的訪問來加速web應用程式。 ...
  • 最近整理了一些資料庫常見的面試題,對自己也是個複習,希望對大家也有所幫助。 1.觸發器的作用? 觸發器是一類特殊的存儲過程,主要是通過事件來觸發而被執行的。它可以強化約束,來維護數據的完整性和一致性,可以跟蹤資料庫內的操作從而不允許未經許可的更新和變化。可以聯級運算。如,某表上的觸發器上包含對另一個 ...
  • 在執行一條HIVE語句的時候報了以下錯誤,重新檢查了所有步驟,重啟所有服務,發現沒有問題。 但發現一個有趣的事情 1,select sno,sname,sex,sage,sdept from student可以正常執行 2,sno,sname,sex,sage,sdept from student ...
  • innodb 的表,直接複製文件是無法使用的,會提示 table doesn’t exists ,在複製的時候,應將data目錄下的 ibdata1 文件一併複製過去,並且刪除 ib_logfile0 、ib_logfile1 文件 ...
  • 今天遇到一個非常奇怪的現象,查看ORACLE資料庫的一個文件,明明這個文件是存在的,但是使用ls -lrt 查看都顯示這個文件不存在。很是納悶! 後面發現在終端輸入文件名後並使用tab鍵時,發現文件後其實是有空格(不可見字元)。如下截圖所示: [oracle@ehvlnx02 ~]$ ls -lrt... ...
  • F.1字元函數——返回字元值 (chr,concat,initcap,lower,lpad/rpad,nls_initcap,nls_lower,nls_upper,regexp_replace,regexp_substr,replace,trim/ltrim/rtrim,soundex,subst ...
  • 視圖和表的區別和聯繫 區別: 1、視圖是已經編譯好的sql語句。而表不是 2、視圖沒有實際的物理記錄。而表有。 3、表是內容,視圖是視窗 4、表只用物理空間而視圖不占用物理空間,視圖只是邏輯概念的存在,表可以及時對它進行修改,但視圖只能有創建的語句來修改 5、表是內模式,視圖是外模式 6、視圖是查看 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...