首頁 資料庫 mysql教程 Oracle DB序列_MySQL

Oracle DB序列_MySQL

Jun 01, 2016 pm 01:28 PM
資料庫

bitsCN.com

Oracle DB序列

 

序列是一个用于创建整数值的数据库对象。可以创建序列,然后再用其生成编号。

序列具有如下特点:

• 可以自动生成唯一编号

• 是一个可共享的对象

• 可用于创建主键值

• 替换应用程序代码

• 如果将序列高速缓存到内存中,则访问序列值的效率会有所提高

 

序列是用户创建的数据库对象,可由多个用户共享来生成整数。

可以通过定义一个序列来生成唯一值,或者回收编号后重新使用相同的编号。

序列的常见用途是创建主键值,每行的主键值必须是唯一的。序列由内部Oracle  例行程序按递增(或递减)方式生成。由于可以减少编写生成序列的例行程序所需的应用程序代码量,因此使用该对象可以节省一些时间。

序列号的存储和生成与表无关。因此,同一序列可以用于多个表。

 

CREATE SEQUENCE 语句:语法

定义一个可以自动生成序号的序列:

CREATE SEQUENCE sequence[INCREMENT BY n][START WITH n][{MAXVALUE n | NOMAXVALUE}][{MINVALUE n | NOMINVALUE}][{CYCLE | NOCYCLE}][{CACHE  n | NOCACHE}];
登入後複製

通过使用CREATE SEQUENCE语句可以自动生成序号。

在该语法中:

sequence:是序列生成器的名称

INCREMENT BY n: 指定序列号之间的间隔,其中n 是一个整数(如果省略此子句,则序列按1 递增)

START WITH n: 指定要生成的第一个序列号(如果省略此子句,则序列从1 开始)

MAXVALUE n: 指定序列可以生成的最大值

NOMAXVALUE 指定10^27 作为递增序列的最大值,而-1 作为递减序列的最大值(这是默认选项)

MINVALUE n :指定最小的序列值

NOMINVALUE :指定1 作为递增序列的最小值,而-(10^26) 作为递减序列的最小值(这是默认选项)

创建序列

• 创建一个名为DEPT_DEPTID_SEQ的序列,将其用作DEPARTMENTS 表的主键。

• 不使用CYCLE选项。

sys@TEST0924> CREATE SEQUENCE dept_deptid_seq  2  INCREMENT BY 10  3  START WITH 120  4  MAXVALUE 9999  5  NOCACHE  6  NOCYCLE  7  ;Sequence created.
登入後複製

CYCLE | NOCYCLE :指定在达到最大值或最小值之后,序列是否继续生成值(NOCYCLE是默认选项)

CACHE n | NOCACHE :指定Oracle Server 预先分配并保留在内存中的值的数量(默认情况下,Oracle Server 会高速缓存20 个值)

示例中创建了一个名为DEPT_DEPTID_SEQ的序列,用作DEPARTMENTS 表的DEPARTMENT_ID 列。该序列从120 开始,不允许高速缓存,也不进行循环。

请勿在序列用于生成主键值时使用CYCLE选项,除非有一个可靠的机制与序列循环相比可以更快地清除旧行。

注:序列与表没有关系。通常,应按序列的预期用途来命名序列。但是,序列可以在任何地方使用,而与其名称无关。

NEXTVAL和CURRVAL伪列

• NEXTVAL会返回下一个可用的序列值。每次被引用时NEXTVAL都会返回一个唯一值,即使对于不同用户也是如此。

• CURRVAL会获得当前序列值。

• 只有对序列发出NEXTVAL之后,CURRVAL才能包含值。

在创建一个序列之后,该序列会生成可以在表中使用的序号。通过使用NEXTVAL和CURRVAL伪列可以引用序列值。

NEXTVAL伪列用于从指定的序列中提取连续的序列号。必须用序列名来限定NEXTVAL。

在引用sequence .NEXTVAL 时,就会生成新的序列号,还会将当前的序列号放在CURRVAL中。

CURRVAL伪列用于引用当前用户刚刚生成的序列号。但是,必须先用NEXTVAL在当前用户的会话中生成一个序列号,然后才能引用CURRVAL。必须用序列名来限定CURRVAL。

在引用sequence .CURRVAL 时,会显示返回给用户进程的最后一个值。

使用NEXTVAL和CURRVAL的规则

可以在下列上下文中使用NEXTVAL和CURRVAL:

• 不是子查询一部分的SELECT 语句的SELECT 列表

• INSERT 语句中子查询的SELECT 列表

• INSERT 语句的VALUES 子句

• UPDATE 语句的SET 子句

不能在下列上下文中使用NEXTVAL和CURRVAL:

• 视图的SELECT 列表

• 带有DISTINCT 关键字的SELECT 语句

• 带有GROUP BY 、HAVING 或ORDER BY 子句的SELECT 语句

• SELECT 、DELETE 或UPDATE 语句中的子查询

• CREATE TABLE或ALTER TABLE 语句中的DEFAULT表达式

使用序列

• 在位置ID 2500 中插入一个名为“Support”的新部门:

sys@TEST0924> INSERT INTO hr.departments(department_id, department_name,location_id)  2  VALUES  (dept_deptid_seq.NEXTVAL, 'Support', 2500);1 row created.
登入後複製

它使用DEPT_DEPTID_SEQ序列生成280的新部门编号。

• 使用sequence_name.CURRVAL查看DEPT_DEPTID_SEQ序列的当前值:

sys@TEST0924> SELECT dept_deptid_seq.CURRVAL FROM dual;   CURRVAL----------       280
登入後複製

假定现在要聘用某些雇员作为新部门的工作人员。在要对所有新雇员执行的INSERT语句中可以包含以下代码:

INSERT INTO employees (employee_id, department_id, ...)VALUES (employees_seq.NEXTVAL, dept_deptid_seq .CURRVAL, ...);
登入後複製

注:上面的示例假设已经创建一个名为 EMPLOYEE_SEQ的序列来生成新雇员编号。

高速缓存序列值

• 将序列值高速缓存在内存中,这样可以更快地对这些值进行访问。

• 在发生以下情况时,序列值会出现间断:

– 发生回退

– 系统崩溃

– 序列已用于其它表中

可以将序列高速缓存在内存中,以便于更快地对这些值进行访问。当首次引用序列时,序列值会被填充到高速缓存中。因此会从高速缓存序列中检索每次请求的下一个新序列值。用完最后一个序列值之后,就会在下一次请求序列时将序列的另一个高速缓存拖入到内存中。

序列中的间断

虽然序列生成器会发出没有间断的序号,但是此操作的发生与提交或回退有关。因此,如果你回退一条包含序列的语句,则会丢失相应的序号。

另一个可能导致序列出现间断的事件是系统崩溃。如果序列值已高速缓存在内存中,那么在系统崩溃时就会丢失一些值。

因为序列不直接与表相关联,所以同一序列可用于多个表。但是,如果同一序列用于多个表,则每个表的序号可能会有间断。

修改序列

更改增量值、最大值、最小值、循环选项或高速缓存选项:

sys@TEST0924> ALTER SEQUENCE  dept_deptid_seq  2  INCREMENT BY 20  3  MAXVALUE 999999  4  NOCACHE  5  NOCYCLE;Sequence altered.
登入後複製

如果序列达到MAXVALUE 限制,则序列不会再分配额外的值,此时你会收到一条错误消息,指明序列超出了MAXVALUE 。要继续使用该序列,可以使用ALTER SEQUENCE语句修改该序列。

语法

ALTER  SEQUENCE sequence[INCREMENT BY n ][{MAXVALUE  n | NOMAXVALUE}][{MINVALUE  n | NOMINVALUE}][{CYCLE | NOCYCLE}][{CACHE  n | NOCACHE}];
登入後複製

在此语法中,sequence 是序列生成器的名称。

修改序列的准则

• 你必须是序列的所有者或拥有序列的ALTER权限。

• 修改只会影响以后生成的序列号。

• 如果要从另一编号处重新开始,则必须删除原有序列后重新创建。

• 在修改过程中会执行一些验证操作。

• 要删除序列,请使用DROP 语句:

sys@TEST0924> DROP SEQUENCE dept_deptid_seq;Sequence dropped.
登入後複製

• 要修改一个序列,你必须是此序列的所有者或拥有序列的ALTER权限。要删除一个序列,你必须是此序列的所有者或拥有此序列的DROP ANY SEQUENCE权限。

• ALTER SEQUENCE 语句只会影响以后生成的序列号。

• 使用ALTER SEQUENCE 语句不能更改START WITH选项。如果要从另一编号处重新开始,则必须删除原有序列后重新创建。

• 在修改过程中会执行一些验证操作。例如,不能强制实施一个小于当前序列号的新MAXVALUE 。

ALTER SEQUENCE dept_deptid_seqINCREMENT BY 20MAXVALUE 90NOCACHENOCYCLE;• 错误:sys@TEST0924> ALTER SEQUENCE  dept_deptid_seq  2  INCREMENT BY 20  3  MAXVALUE 99  4  NOCACHE  5  NOCYCLE;ALTER SEQUENCE  dept_deptid_seq*ERROR at line 1:ORA-04009: MAXVALUE cannot be made to be less than the current value
登入後複製

 


bitsCN.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1317
25
PHP教程
1268
29
C# 教程
1247
24
iOS 18 新增「已復原」相簿功能 可找回遺失或損壞的照片 iOS 18 新增「已復原」相簿功能 可找回遺失或損壞的照片 Jul 18, 2024 am 05:48 AM

蘋果公司最新發布的iOS18、iPadOS18以及macOSSequoia系統為Photos應用程式增添了一項重要功能,旨在幫助用戶輕鬆恢復因各種原因遺失或損壞的照片和影片。這項新功能在Photos應用的"工具"部分引入了一個名為"已恢復"的相冊,當用戶設備中存在未納入其照片庫的圖片或影片時,該相冊將自動顯示。 "已恢復"相簿的出現為因資料庫損壞、相機應用未正確保存至照片庫或第三方應用管理照片庫時照片和視頻丟失提供了解決方案。使用者只需簡單幾步

Hibernate 如何實作多型映射? Hibernate 如何實作多型映射? Apr 17, 2024 pm 12:09 PM

Hibernate多態映射可映射繼承類別到資料庫,提供以下映射類型:joined-subclass:為子類別建立單獨表,包含父類別所有欄位。 table-per-class:為子類別建立單獨資料表,僅包含子類別特有列。 union-subclass:類似joined-subclass,但父類別表聯合所有子類別列。

如何在PHP中處理資料庫連線錯誤 如何在PHP中處理資料庫連線錯誤 Jun 05, 2024 pm 02:16 PM

PHP處理資料庫連線報錯,可以使用下列步驟:使用mysqli_connect_errno()取得錯誤代碼。使用mysqli_connect_error()取得錯誤訊息。透過擷取並記錄這些錯誤訊息,可以輕鬆識別並解決資料庫連接問題,確保應用程式的順暢運作。

在PHP中使用MySQLi建立資料庫連線的詳盡教學 在PHP中使用MySQLi建立資料庫連線的詳盡教學 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立資料庫連線:包含MySQLi擴充(require_once)建立連線函數(functionconnect_to_db)呼叫連線函數($conn=connect_to_db())執行查詢($result=$conn->query())關閉連線( $conn->close())

如何在 Golang 中使用資料庫回呼函數? 如何在 Golang 中使用資料庫回呼函數? Jun 03, 2024 pm 02:20 PM

在Golang中使用資料庫回呼函數可以實現:在指定資料庫操作完成後執行自訂程式碼。透過單獨的函數新增自訂行為,無需編寫額外程式碼。回調函數可用於插入、更新、刪除和查詢操作。必須使用sql.Exec、sql.QueryRow或sql.Query函數才能使用回呼函數。

如何在 Golang 中將 JSON 資料保存到資料庫中? 如何在 Golang 中將 JSON 資料保存到資料庫中? Jun 06, 2024 am 11:24 AM

可以透過使用gjson函式庫或json.Unmarshal函數將JSON資料儲存到MySQL資料庫中。 gjson函式庫提供了方便的方法來解析JSON字段,而json.Unmarshal函數需要一個目標類型指標來解組JSON資料。這兩種方法都需要準備SQL語句和執行插入操作來將資料持久化到資料庫中。

如何用 Golang 連接遠端資料庫? 如何用 Golang 連接遠端資料庫? Jun 01, 2024 pm 08:31 PM

透過Go標準庫database/sql包,可以連接到MySQL、PostgreSQL或SQLite等遠端資料庫:建立包含資料庫連接資訊的連接字串。使用sql.Open()函數開啟資料庫連線。執行SQL查詢和插入操作等資料庫操作。使用defer關閉資料庫連線以釋放資源。

PHP與不同資料庫的連接:MySQL、PostgreSQL、Oracle和更多 PHP與不同資料庫的連接:MySQL、PostgreSQL、Oracle和更多 Jun 01, 2024 pm 03:02 PM

PHP連接資料庫指南:MySQL:安裝MySQLi擴展,建立連線(servername、username、password、dbname)。 PostgreSQL:安裝PgSQL擴展,建立連線(host、dbname、user、password)。 Oracle:安裝OracleOCI8擴展,建立連線(servername、username、password)。實戰案例:取得MySQL資料、PostgreSQL查詢、OracleOCI8更新記錄。

See all articles