oracle表中怎么建序列

oracle表中怎么建序列,第1张

oracle表中创建序列语法:

CREATE SEQUENCE name

[INCREMENT BY n]

[START WITH n]           

[{MAXVALUE n | NOMAXVALUE}]

[{MINVALUE n | NOMINVALUE}]

[{CYCLE | NOCYCLE}]

[{CACHE n | NOCACHE}]

示例:

increment by n:表明值每次增长n(步长)。

start with n: 从n开始。

{MAXVALUE n | NOMAXVALUE}: 设置最大值。

{MINVALUE n | NOMINVALUE}: 设置最小值,start with不能小于最小值。

CYCLE | NOCYCLE          : 是否循环,建议不使用

CACHE n | NOCACHE    : 是否启用缓存。

2、插入数据到表中

示例:

INSERT INTO emp VALUES

(emp_sequence .nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20)

Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。

ORACLE数据库是目前世界上使用最为广泛的数据库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能;作为一个关系数据库,它是一个完备关系的产品;作为分布式数据库它实现了分布式处理功能。

扩展资料:

sql server数据库里建序列:

alter table cust_info add sequence int

insert into cust_info (sequence)

select row_number() over(order by cust_id) as cust_id_seq from cust_info

这个还真不好做,

一般在写代码时,先取出序列的nextval,放到insert语句中去;

比如:

ida := seq_a.nextval

insert into taba(id,value,...) values(ida,'abc',...)

或者在insert语句中直接使用序列的nextval:

insert into taba(id,value,...) values(seq_a.nextval,'abc',...)

或者用触发器实现自增长:

比如表名:tab,主键为:id

1. 增加一个序列号: create sequence seq_tab

2. 增加一个触发器,如果是insert,则取序列号值,赋予主键列

CREATE OR REPLACE TRIGGER TRI_tab

BEFORE INSERT ON tab FOR EACH ROW

DECLARE

-- LOCAL VARIABLES HERE

BEGIN

IF :NEW.id IS NULL THEN

SELECT SEQ_tab.NEXTVAL INTO :NEW.id FROM DUAL

END IF

END TRI_tab


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/11348298.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-15
下一篇2023-05-15

发表评论

登录后才能评论

评论列表(0条)

    保存