mysql实现oracle sequence方案
转自: http://blog.csdn.net/javaGirlOne/article/details/47256183
背景:先总结一下MYSQL 自增长与ORACLE 序列的区别:
自增长只能用于表中的其中一个字段
自增长只能被分配给固定表的固定的某一字段,不能被多个表共用.
自增长会把一个未指定或NULL值的字段自动填上.
实验:我们可以用创建一个序列表,使用函数来获取序列的值
1. 新建序列表
- drop table if exists tb_sequence;
- create table tb_sequence (
- seq_name VARCHAR(50) NOT NULL, -- 序列名称
- current_val INT NOT NULL, -- 当前值
- increment_val INT NOT NULL DEFAULT 1, -- 步长(跨度)
- PRIMARY KEY (seq_name) );
2、 新增一个序列
- <pre name="code" class="sql">INSERT INTO tb_sequence VALUES ('seq_test1_num1', '0', '1');
- INSERT INTO tb_sequence VALUES ('seq_test1_num2', '0', '2');
3、创建 函数 用于获取序列当前值(v_seq_name 参数值 代表序列名称)
- <pre name="code" class="sql">create function currval(v_seq_name VARCHAR(50))
- returns integer
- begin
- declare value integer;
- set value = 0;
- select current_val into value from tb_sequence where seq_name = v_seq_name;
- return value;
- end;
4、查询当前值
- <pre name="code" class="sql">select currval('seq_test1_num1');
5、创建 函数 用于获取序列下一个值(v_seq_name 参数值 代表序列名称)
- <pre name="code" class="sql">create function nextval (v_seq_name VARCHAR(50))
- returns integer
- begin
- update tb_sequence set current_val = current_val + increment_val where seq_name = v_seq_name;
- return currval(v_seq_name);
- end;
6、 查询下一个值
- select nextval('seq_test1_num1');
7、新建表 用于测试的表
- <pre name="code" class="sql">DROP TABLE IF EXISTS `test1`;
- CREATE TABLE `test1` (
- `name` varchar(255) NOT NULL,
- `value` double(255,0) DEFAULT NULL,
- `num1` int(11) DEFAULT NULL,
- `num2` int(11) DEFAULT NULL,
- PRIMARY KEY (`name`)
- );
8、 新建触发器 插入新纪录前给自增字段赋值实现字段自增效果
- <pre name="code" class="sql">CREATE TRIGGER `TRI_test1_num1` BEFORE INSERT ON `test1` FOR EACH ROW BEGIN
- set NEW.num1 = nextval('seq_test1_num1');
- set NEW.num2 = nextval('seq_test1_num2');
- END
9、 最后测试自增效果
- <pre name="code" class="sql">INSERT INTO test1 (name, value) VALUES ('1', '111');
- INSERT INTO test1 (name, value) VALUES ('2', '222');
- INSERT INTO test1 (name, value) VALUES ('3', '333');
- INSERT INTO test1 (name, value) VALUES ('4', '444');
10、实验结果
- <pre name="code" class="sql">SELECT * FROM test1;
mysql实现oracle sequence方案的更多相关文章
- Oracle和MySQL的高可用方案对比【转】
关于Oracle和MySQL的高可用方案,其实一直想要总结了,就会分为几个系列来简单说说.通过这样的对比,会对两种数据库架构设计上的细节差异有一个基本的认识.Oracle有一套很成熟的解决方案.用我在 ...
- 数据库MySQL与Oracle的一些去O注意项
一.oracle递归查询语句start with ...connect by prior ① 给你一张表,表里面有主键id,以及该项的父节点parent_id,查询出该表中所有的父子关系节点树? Or ...
- mysql实现oracle序列
mysql实现oracle序列的方案1.建表,表结构为:drop table if exists sequence; create table sequence ( seq_name VARCHAR( ...
- MySql和Oracle的日期转换到底有哪些不同?我们来比较一下
1.MySql和Oracle的日期转换 mysql中有2种日期格式DATE和TIME,oracle只有一种日期格式DATE. oracle> select to_char(sysdate,'yy ...
- 数据库高可用架构(MySQL、Oracle、MongoDB、Redis)
一.MySQL MySQL小型高可用架构 方案:MySQL双主.主从 + Keepalived主从自动切换 服务器资源:两台PC Server 优点:架构简单,节省资源 缺点:无法线性扩展,主从失 ...
- 【转】MySQL中增加sequence管理功能(模拟创建sequence)
1.oracel可以直接支持sequence,但是mysql不支持sequence,因此我们要通过模拟sequence的方法在mysql中创建sequence.模拟sequence的方法:项目场景:项 ...
- [转]数据库高可用架构(MySQL、Oracle、MongoDB、Redis)
一.MySQL MySQL小型高可用架构 方案:MySQL双主.主从 + Keepalived主从自动切换 服务器资源:两台PC Server 优点:架构简单,节省资源 缺点:无法线性扩展,主从失 ...
- 《物联网框架ServerSuperIO教程》-19.设备驱动和OPC Client支持mysql、oracle、sqlite、sqlserver的持久化。v3.6.4版本发布
19.设备驱动和OPC Client支持mysql.oracle.sqlite.sqlserver的持久化 19.1 概述 ServerSuperIO支持设备驱动和OPC Client采集的数 ...
- MySQL,Oracle,PostgreSQL 数据库web维护客户端管理工具
TreeDMS数据库管理系统使用JAVA开发,采用稳定通用的springMVC +JDBC架构,实现基于WEB方式对 MySQL,Oracle,PostgreSQL 等数据库进行维护管理操作. 功能包 ...
随机推荐
- 更改backend
keras默认的backend是tensorflow,更改成theano方法如下: vim ~/.keras/keras.json { "image_dim_ordering":& ...
- springmvc项目打war包部署到tomcat访问路径去掉项目名
一般来说,部署到tomcat则是把war包丢到webapps目录下,启动Tomcat会自动解压,成一个war包名称的文件夹项目, 例如imgManager.war 访问的地址一般是localhost: ...
- jlink RTT 打印 BUG , FreeRTOS 在开启 tickless 模式下 无法使用的问题
一开始我以为是 jlink 的问题,后面发现是 tickless 模式搞鬼 tickless 模式下 ,内核 会 根据任务需求,会停止工作,这个时候 jlink rtt 打印就会失效!!! 不过 NR ...
- #leetcode刷题之路45-跳跃游戏 II
给定一个非负整数数组,你最初位于数组的第一个位置.数组中的每个元素代表你在该位置可以跳跃的最大长度.你的目标是使用最少的跳跃次数到达数组的最后一个位置. 示例:输入: [2,3,1,1,4]输出: 2 ...
- Vue+axios 实现http拦截及vue-router拦截
现如今,每个前端对于Vue都不会陌生,Vue框架是如今最流行的前端框架之一,其势头直追react.最近我用vue做了一个项目,下面便是我从中取得的一点收获. 基于现在用vue+webpack搭建项目的 ...
- mac 下安装php7.1 memcache扩展
1.下载memcache源代码文件 https://github.com/websupport-sk/pecl-memcache/archive/php7.zip 文件夹名为:pecl-memcach ...
- C语言实现随机数
最近在看<The C Programming Language>这本书,看到一个关于随机数的知识点,有种豁然开朗的感觉.以前总靠死记硬背,也不明白为啥是这样,而且总把srand()遗漏.相 ...
- springboot快速入门(四)——数据库操作
一.Spring-Data-Jpa的引入 先给出官方文档:https://docs.spring.io/spring-data/jpa/docs/current/reference/html/ IBM ...
- 2017-2018-1 20155315 《信息安全系统设计基础》嵌入式C语言测试
Hours 要求 伪代码 提取Hours 提取时间地址 时间存放在(基址+2)的16位寄存器中,定义一个时间宏存放地址. #define Time_Addr 0xFFFFC0000 #define T ...
- vba 批量生成条形图代码
Sub hong3()'' 宏3 宏d Dim a, b As Integer Dim str As String For a = 227 To 947 Step 15 b = a + 5 str = ...