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 等数据库进行维护管理操作. 功能包 ...
随机推荐
- bootstrap 多选款样式:bootstrap-switch
有时候,为了美化checkbox后者radio的时候,让用户体验起来更好,jquery里有icheck. bootstrap里有bootstrap-switch,就简单介绍下bootstrap-swi ...
- Kafka设计解析(九)为何去掉replica.lag.max.messages参数
转载自 huxihx,原文链接 Kafka副本管理—— 为何去掉replica.lag.max.messages参数 在Kafka设计解析(二)Kafka High Availability (上)文 ...
- PAT乙级1027
1027 打印沙漏 (20 分) 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个“*”,要求按下列格式打印 ***** *** * *** ***** 所谓“沙漏形状”,是指每行输 ...
- gulp合并压缩
1.文件合并压缩 var concat = require(‘gulp-concat’); //引用 var uglify = require(‘gulp-uglify’); 接下来,只要conca ...
- P1736 创意吃鱼法
题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她发现,把大池子视为01矩阵(0表示对应位置无鱼,1 ...
- 50个国内外最棒的C/C++源码站点分享
C/C++是最基本的编程语言.这里列出了50名优秀站点和网页清单,这些站点提供c/c++源码.这份清单提供了源码的链接以及它们的小说明.我已 尽力包含最佳的C/C++源码的站点.这不是一个完整的清单, ...
- 偏前端 - jquery-iframe内触发父窗口自定义事件-
例如父窗口定义了一个事件. top: $(dom1).bind('topEvent', function(){}); 那么iframe里面的元素怎样触发父窗口dom1的事件呢?这样吗? $(dom1, ...
- 深入虚拟内存(Virtual Memory,VM)
我们应该知道物理内存(Physical Memory)指的是硬件上的内存,即 RAM.它通常指的是插在主板上的内存条,给进程提供临时数据存储的设备.因为 CPU 可以直接从物理内存中读取数据和指令,所 ...
- Verilog 位拼接运算符的优先级
最近研究FIFO的时候,在开源工程中看到这样一段代码 ; always @(posedge rd_clk) {'b0}}; else {'b0}}; else if(re) rp_bin <= ...
- FPGA之CORDIC算法实现_理论篇(上)
关于cordic的算法原理核心思想就是规定好旋转角度,然后通过不停迭代逐步逼近的思想来实现数学求解,网上关于这部分的资料非常多,主要可以参考: 1)https://blog.csdn.net/qq_3 ...