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 等数据库进行维护管理操作. 功能包 ...
随机推荐
- Property Injection in Asp.Net Core (转载)
问: I am trying to port an asp.net application to asp.net core. I have property injection (using ninj ...
- UNIX网络编程 卷2 源代码使用
1. 下载源码,W. Richard Stevens的主页:http://www.kohala.com/start/ wget http://www.kohala.com/start/unpv22e/ ...
- window.open 防止浏览器拦截
https://blog.csdn.net/sinat_37255207/article/details/89374416 网上试了很多方法 最终只有一种可以 var newWin = window. ...
- Angular4 自制打地鼠游戏
前端工程师新手一枚,之前一直做些小设计,以及静态页面的编写工作.刚刚接触 Angular 没有多久,四个月前对于 Javascript也只是会写 alert 之流,现在进步算是很大,下面是自制的打地鼠 ...
- 20155239 2017-11-19 实现mypwd(选做,加分)
20155239 2017-11-19 实现mypwd(选做,加分) 题目和要求 学习pwd命令 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 实现mypwd 测试mypwd ...
- 《Java 程序设计》课堂实践项目汇总链接
1.<Java 程序设计>课堂实践项目-命令行参数 2.<Java 程序设计>课堂实践项目-mini dc 3.<Java 程序设计>课堂实践项目-Arrays和S ...
- mysql数据库的左连接,右连接,内链接。
一般所说的左连接,外连接是指左外连接,右外连接.做个简单的测试你看吧.先说左外连接和右外连接:[TEST1@orcl#16-12月-11] SQL>select * from t1; ID NA ...
- win10操作系统vs2010编译osg3.4.0问题解决记录
参考博客:OSG3.4.0+VS2010+WIN10编译及二次开发环境搭建 链接:https://blog.csdn.net/hsc1239653453/article/details/7827856 ...
- 苏州Uber优步司机奖励政策(4月21日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- matlab GUI工作原理
例如,用GUIDE创建名为ceshi的GUI程序,其m文件的主函数有如下形式.那么,打开该GUI时,它到底是怎么运行的呢?以下略作小结,欢迎大家补充 function varargout = cesh ...