msql 实现sequence功能增强
create table sequence (
seq_name VARCHAR(50) NOT NULL COMMENT '序列名称',
min_val INT UNSIGNED NOT NULL COMMENT '最小值',
max_val INT UNSIGNED NOT NULL COMMENT '最大值',
if_cycle INT UNSIGNED NOT NULL COMMENT '是否循环',
if_use INT UNSIGNED NOT NULL COMMENT '是否使用中:0:未使用,1:已使用',
current_val INT UNSIGNED NOT NULL COMMENT '当前值',
increment_val INT UNSIGNED NOT NULL DEFAULT 1 COMMENT '步长(跨度)',
PRIMARY KEY (seq_name)
);
delimiter $$
create function currval(v_seq_name VARCHAR(50))
returns integer
begin
declare v_curr_val integer;
set v_curr_val := 0;
select current_val into v_curr_val
from sequence
where seq_name = v_seq_name;
return v_curr_val;
end$$
create function nextval(v_seq_name VARCHAR(50))
returns INTEGER
begin
declare v_curr_val INTEGER;
declare v_increment_val INTEGER;
declare v_if_cycle INTEGER;
declare v_next_val INTEGER;
declare v_min_val INTEGER;
declare v_max_val INTEGER;
update sequence set if_use = 1 where seq_name = v_seq_name;
select current_val, min_val, max_val, increment_val, if_cycle
into v_curr_val, v_min_val, v_max_val, v_increment_val, v_if_cycle from sequence where seq_name = v_seq_name;
set v_next_val := v_curr_val + v_increment_val;
if (v_next_val > v_max_val) and (v_if_cycle = 0) then
set v_next_val := -1;
else
set v_next_val := mod(v_next_val, v_max_val + 1);
IF v_next_val < v_min_val then
set v_next_val := v_min_val;
end if;
update sequence set current_val = v_next_val where seq_name = v_seq_name;
end if;
update sequence set if_use = 0 where seq_name = v_seq_name;
return v_next_val;
end$$
create function setval(v_seq_name VARCHAR(50), v_new_val INTEGER)
returns integer
begin
declare v_min_val int;
declare v_max_val int;
update sequence set if_use = 1 where seq_name = v_seq_name;
select min_val, max_val into v_min_val, v_max_val from sequence where seq_name = v_seq_name;
if (v_new_val > v_max_val) or (v_new_val < v_min_val) then
set v_new_val := -1;
else
update sequence set current_val = v_new_val where seq_name = v_seq_name;
end if;
update sequence set if_use = 0 where seq_name = v_seq_name;
return v_new_val;
end$$
delimiter ;
msql 实现sequence功能增强的更多相关文章
- MWeb 1.4 新功能介绍二:静态博客功能增强
MWeb 比较有特色的是一键生成静态博客功能,然后从 MWeb 最开始规划要做静态博客生成功能时,我就希望 MWeb 的静态博客生成功能在易用的同时,还要有很强大的扩展性. 比如说能自己增加网站公告, ...
- VMare中安装“功能增强工具”,实现CentOS5.5与win7host共享文件夹的创建
读者如要转载,请标明出处和作者名,谢谢. 地址01:http://space.itpub.net/25851087 地址02:http://www.cnblogs.com/zjrodger/ 地址03 ...
- Java SE 5.0 - SE 8 的功能增强
Table of Contents 前言 Java 5.0 Generics Enhanced for Loop Autoboxing Typesafe Enums Varargs Static Im ...
- jquery-7 jquery中的文档处理方法有哪些(方法的参数表示功能增强)
jquery-7 jquery中的文档处理方法有哪些(方法的参数表示功能增强) 一.总结 一句话总结:多看参考文档,多看主干目录.一般的功能分两个方法来实现,一个对应标签,一个对应标签和事情,比如克隆 ...
- DevExpress WPF v19.1:Data Grid/Tree List等控件功能增强
行业领先的.NET界面控件DevExpress 日前正式发布v19.1版本,本站将以连载的形式介绍各版本新增内容.在本系列文章中将为大家介绍DevExpress WPF v19.1中新增的一些控件及部 ...
- DevExpress WinForms v19.1新版亮点:Spreadsheet/Sunburst控件功能增强
行业领先的.NET界面控件DevExpress v19.1终于正式发布,本站将以连载的形式介绍各版本新增内容.在本系列文章中将为大家介绍DevExpress WinForms v19.1中新增的一些控 ...
- Kubernetes 弹性伸缩HPA功能增强Advanced Horizontal Pod Autoscaler -介绍部署篇
背景 WHAT(做什么) Advanced Horizontal Pod Autoscaler(简称:AHPA)是kubernetes中HPA的功能增强. 在兼容原生HPA功能基础上,增加预测.执行模 ...
- Tapdata Cloud 版本上新!新增TiDB等数据源支持,连接和任务功能增强,体验更优
Tapdata Cloud cloud.tapdata.net Tapdata Cloud 是国内首家异构数据库实时同步云平台,目前支持Oracle.MySQL.PG.SQL Server.Mongo ...
- ORACLE 12C RMAN 功能增强
在ORACLE 12C中对rman的功能有了不少增强,在以前的文章中写过RMAN RECOVER TABLE功能,这里另外补充rman增强的两个小功能(sql语句和数据文件分割)数据库版本 SQL&g ...
随机推荐
- vs2010 2013 2015+ 必备插件精选(15个)
转 http://www.spersky.com/post/vsPlugins.html 我目前主要用的是Hide Main Page——公司配给的电脑屏幕分辨率好小,还是1366*768的,去掉头可 ...
- 包管理工具Carthage使用
iOS项目中第三方开源库的工具有Cocoapods和Carthage,swift官方出了一个包管理工具SPM(Swift Package Manager). 首先,大体讲一下Cocoapods和Car ...
- zookeeper+jstorm的集群搭建
zookeeper的配置: zookeeper有三种配置方式:单机式/伪分布式/集群式 其中伪分布式是在一台电脑上通过不同的端口来模拟分布式情形,需要N份配置文件和启动程序,而集群式是多个zookee ...
- shell面试题目总结
1.如何理解shell脚本中第一行#!/bin/sh #!为特殊的表示符,其后是解释此脚本的shell的路径.此脚本使用/bin/sh进行解释执行. 2.如何向脚本传递参数. 脚本名字 参数1 参数2 ...
- (转载)两种方法让HashMap线程安全
HashMap不是线程安全的,往往在写程序时需要通过一些方法来回避.其实JDK原生的提供了2种方法让HashMap支持线程安全. 方法一:通过Collections.synchronizedMap() ...
- DOM中文本节点索引方法
问题 对于 jquery 接口text()只能取到有标签的 dom对象中 文本内容. 如果索引对象本身就是文本节点,则不好索引到, 没有相关的索引选择器. 例如: 对于<input>aaa ...
- 分享一组矢量图标–UX图标字体库
以下内容转自:http://ux.etao.com/,原文链接:http://ued.alimama.com/posts/219 科技日新月异的今天,市面上各种分辨率.各种显示精度的显示设备层出不穷, ...
- TIJ——Chapter Seven:Reusing Classes
Reusing Classes 有两种常用方式实现类的重用,组件(在新类中创建存在类的对象)和继承. Composition syntax Every non-primitive object has ...
- linux------------Another app is currently holding the xtables lock. Perhaps you want to use the -w option?
今天突然遇到这个么一个奇葩的问题,直接说问题的原因:原因是我们创建了一个计划任务,这个计划任务是一分钟执行一次,是iptables封ip的一个sh脚本.由于攻击我们的ip太多,已经达到了几千个,这个脚 ...
- Java中Map的三种遍历方法
Map的三种遍历方法: 1. 使用keySet遍历,while循环: 2. 使用entrySet遍历,while循环: 3. 使用for循环遍历. 告诉您们一个小秘密: (下↓面是测试代码,最爱看 ...