dual mysql 获取序列_Oracle与Mysql操作表序列

本文介绍了在Oracle和MySQL中创建及使用序列的方法。在Oracle中,通过CREATE SEQUENCE语句定义序列,并使用currval和nextval获取序列值。而在MySQL中,需要创建管理表sequence,以及currval、nextval和setval三个函数来实现类似的功能。
摘要由CSDN通过智能技术生成

一、Oracle添加表序列

CREATE SEQUENCE name -- 序列名

INCREMENT BY -- 每次加几个

START WITH -- 从几开始计数

MINVALUE --- 最小值

MAXVALUE --- 最大值

NOCACHE --- 没有缓存

CACHE --- 缓存 默认为20,最少为2个

NOCYCLE --- 一直累加,不循环

例如:

drop SEQUENCE FILE_SEQ;

CREATE SEQUENCE FILE_SEQ

INCREMENT BY1START WITH1MINVALUE1MAXVALUE99999999999999NOCYCLE

CACHE2;

生成后如图:

获取当前序列

select 序列名.currval from dual; //获取序列的当前值,这个值是可变的。

需要注意的是:

数据库连接成功后,初次执行这句话,会报异常,不能用。

如果不是你的语句单词拼写错误,就是因为没有先执行下边这句sql,

获取下一个序列

select 序列名.nextval from dual

二、MySql添加表序列

第一步:创建Sequence管理表 sequence

DROP TABLE IF EXISTS sequence;

CREATE TABLE sequence (

name VARCHAR(50) NOT NULL,

current_value INT NOT NULL,

increment INT NOT NULL DEFAULT1,

PRIMARY KEY (name)

) ENGINE=InnoDB;

第二步:创建取当前值的函数 currval

DROP FUNCTION IF EXISTS currval;

DELIMITER $

CREATE FUNCTION currval (seq_name VARCHAR(50))

RETURNS INTEGER

LANGUAGE SQL

DETERMINISTIC

CONTAINS SQL

SQL SECURITY DEFINER

COMMENT''BEGIN

DECLARE value INTEGER;

SET value= 0;

SELECT current_value INTO value

FROM sequence

WHERE name=seq_name;

RETURN value;

END

$

DELIMITER ;

第三步:创建取下一个值的函数 nextval

DROP FUNCTION IF EXISTS nextval;

DELIMITER $

CREATE FUNCTION nextval (seq_name VARCHAR(50))

RETURNS INTEGER

LANGUAGE SQL

DETERMINISTIC

CONTAINS SQL

SQL SECURITY DEFINER

COMMENT''BEGIN

UPDATE sequence

SET current_value= current_value +increment

WHERE name=seq_name;

RETURN currval(seq_name);

END

$

DELIMITER ;

第四步:创建更新当前值的函数 setval

DROP FUNCTION IF EXISTS setval;

DELIMITER $

CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)

RETURNS INTEGER

LANGUAGE SQL

DETERMINISTIC

CONTAINS SQL

SQL SECURITY DEFINER

COMMENT''BEGIN

UPDATE sequence

SET current_value=value

WHERE name=seq_name;

RETURN currval(seq_name);

END

$

DELIMITER ;

备注:以上sql中DELIMITER与后面的分号有一个空格或者执行会报错 。

测试:

INSERT INTO sequence VALUES ('TestSeq', 0, 1);----添加一个sequence名称和初始值,以及自增幅度 添加一个名为TestSeq 的自增序列

SELECT SETVAL('TestSeq', 10);---设置指定sequence的初始值 这里设置TestSeq 的初始值为10

SELECT CURRVAL('TestSeq');--查询指定sequence的当前值 这里是获取TestSeq当前值

SELECT NEXTVAL('TestSeq');--查询指定sequence的下一个值 这里是获取TestSeq下一个值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将 Oracle 序列迁移到 MySQL,需要考虑到两个数据库之间的差异。在 Oracle 中,序列是自动递增的整数值生成器,而 MySQL 中没有直接的序列类型。以下是一个迁移序列的一般步骤: 1. 创建一个 MySQL 来模拟序列:在 MySQL 中,您可以创建一个包含一个自增列的来模拟序列。例如,创建一个名为 `sequence_table` 的,其中包含一个名为 `sequence_value` 的自增列。 2. 导出 Oracle 序列的当前值:使用 Oracle SQL 查询来获取序列的当前值。例如,对于名为 `my_sequence` 的序列,您可以运行如下查询:`SELECT my_sequence.CURRVAL FROM dual;`。 3. 将导出的当前值插入到模拟序列中:将步骤 2 中导出的序列当前值插入到 MySQL 的模拟序列中。 例如,使用以下查询将序列当前值插入到 `sequence_table` 中: ```sql INSERT INTO sequence_table (sequence_value) VALUES (<当前值>); ``` 4. 创建一个在 MySQL 中自增的列:在需要使用序列MySQL 中,创建一个自增列,以模拟 Oracle 序列的行为。例如,创建一个名为 `id` 的自增列。 5. 更新的自增列的起始值:使用 `ALTER TABLE` 语句来更新自增列的起始值,以与步骤 2 中导出的当前值匹配。 例如,使用以下查询将 `id` 列的起始值更新为模拟序列中的当前值: ```sql ALTER TABLE your_table AUTO_INCREMENT = <当前值>; ``` 现在,您可以使用 MySQL 中的自增列来模拟 Oracle 序列的行为。请注意,这只是一种模拟方法,可能无法完全复制 Oracle 序列的所有行为。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值