mysql实现nextVal功能

首先创建表:

CREATE TABLE `sys_sequence` (

`NAME` varchar(50) NOT NULL,

`CURRENT_VALUE` int(11) NOT NULL DEFAULT '0',

`INCREMENT` int(11) NOT NULL DEFAULT '1',

PRIMARY KEY (`NAME`)

)

插入记录

INSERT INTO SYS_SEQUENCE(NAME,CURRENT_VALUE,INCREMENT) VALUES('TBL_FS', 1,1)

DELIMITER $$

DROP FUNCTION IF EXISTS `currval`$$

CREATE DEFINER=`root`@`%` FUNCTION `currval`(seq_name VARCHAR(50)) RETURNS INT(11)

BEGIN

DECLARE VALUE INTEGER;

SET VALUE=0;

SELECT current_value INTO VALUE

FROM sys_sequence

WHERE NAME=seq_name;

RETURN VALUE;

END$$

DELIMITER ;

查询当前记录:

select currval('TBL_FS');

如果出现Error Code: 1449 The user specified as a definer ('root'@'%') does not exist 错误,则执行如下sql:

grant all privileges on . to root@"%" identified by "password";

flush privileges;

继续执行当前记录sql则成功

创建nextval函数

DELIMITER $$

DROP FUNCTION IF EXISTS `nextval`$$

CREATE DEFINER=`root`@`%` FUNCTION `nextval`(seq_name varchar(50)) RETURNS int(11)

BEGIN

UPDATE sys_sequence

SET CURRENT_VALUE = CURRENT_VALUE + INCREMENT

where name=seq_name;

return currval(seq_name);

END$$

DELIMITER ;

执行nextval函数

select nextval('tbl_fs')

创建函数过程中出现This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de 错误

这是我们开启了bin-log, 我们就必须指定我们的函数是否是

1 DETERMINISTIC 不确定的

2 NO SQL 没有SQl语句,当然也不会修改数据

3 READS SQL DATA 只是读取数据,当然也不会修改数据

4 MODIFIES SQL DATA 要修改数据

5 CONTAINS SQL 包含了SQL语句

其中在function里面,只有 DETERMINISTIC, NO SQL 和 READS SQL DATA 被支持。如果我们开启了 bin-log, 我们就必须为我们的function指定一个参数。

在MySQL中创建函数时出现这种错误的解决方法:

set global log_bin_trust_function_creators=TRUE;

nextval mysql_mysql实现nextVal功能相关推荐

  1. oracle nextval mysql_mysql中实现类似oracle中的nextval函数

    我们知道mysql中是不支持sequence的,一般是建表的时间使这个字段自增. 如       create table table_name(id int auto_increment prima ...

  2. mysql 实现nextval_mysql实现nextVal功能

    首先创建表: CREATE TABLE `sys_sequence` ( `NAME` varchar(50) NOT NULL, `CURRENT_VALUE` int(11) NOT NULL D ...

  3. oracle rpad mysql_Oracle生成不重复票号与LPAD,RPAD与NEXTVAL函数解析

    SELECT TO_CHAR(SYSDATE,'YYMMDD')||LPAD(REFUNDSEQ.NEXTVAL,6,'0') AS RES_ORDER_NO FROM DUAL 该语句拼接 时间 与 ...

  4. 串的模式匹配、KMP算法、nextval数组求法

    一.暴力匹配 #include <iostream> using namespace std; #define MAXLEN 255 typedef struct{char ch[MAXL ...

  5. 手算KMP匹配的Next值和Nextval值(转载)

    KMP 算法我们有写好的函数帮我们计算 Next 数组的值和 Nextval 数组的值,但是如果是考试,那就只能自己来手算这两个数组了,这里分享一下我的计算方法吧. 计算前缀 Next[i] 的值: ...

  6. kmp有next和nextval的C语言,KMP模式匹配算法中next和nextval的求解(轉)

    KMP算法相關 轉載自:http://blog.sina.com.cn/s/blog_85b0ae450101j2iy.html KMP算法由兩部分組成: 第一部分,計算模式串的next或nextva ...

  7. 数据结构-KMP手算next与nextval(全网最简单,包会)

    手算next值与nextval,全网最简单,时间关系,就不手打了(考完研后又手打了一遍,与图片一致). 直接把笔记内容图片粘贴了,绝对最简单.有问题的话,下方评论. 方法1:引入了一个maxL,在计算 ...

  8. KMP算法,字符串匹配,next与nextval数组求解

    目录 KMP算法简介 next数组手动求解过程 next数组求解(代码实现) 改进的KMP算法 手动求解nextval数组 nextval数组求解(代码实现) KMP算法简介 KMP算法是一种改进的字 ...

  9. nextval数组求解

    nextval数组求解过程 为什么用nextval数组 nextval数组求解方式 一.模式串的下标从0开始,nextval数组求解方式详解: 代码实现 二.模式串的下标从1开始,nextval数组求 ...

最新文章

  1. 基于OpenCV实战:提取中心线
  2. Python 技术篇-用PIL库旋转图片、改变图像尺寸
  3. crt脚本怎么添加等待时间_secureCRT自动化脚本(之定时任务)
  4. hmr webpack 不编译_webpack HMR未加载更改
  5. php.c drcom,校园网绕过Drcom安装自动登录程序到路由器
  6. NYOJ题目 263 精挑细选
  7. Adobe_Audition消除人声
  8. 关于python安装scipy模块的问题
  9. qt 处理oracle事务,qt调用oracle存储过程,该怎么处理(2)
  10. MATLAB 距离函数及用法
  11. Android VLC 加载ass字幕乱码问题
  12. div+css网页html成品学生作业包含10个html页面——动漫主题海贼王
  13. android3d画廊自动切换,Android ViewPager打造3D画廊
  14. MySQL报错:The server quit without updating PID file 我的解决思路和方法
  15. Linux 基础资料
  16. 亲爱的波特兰——CJ麦科勒姆告别信
  17. java练习案例_Java版打字练习案例源码
  18. lan9252、lan9253和lan9254参数比较
  19. 02 C/C++创建tcl自定义命令
  20. 《GitHub详细教程》

热门文章

  1. 今天主要谈谈关于申请美国专利的一些问题
  2. 在视频海洋里徜徉的年轻人,618都是怎么选手机的?
  3. mysql add column_SQL Add Column
  4. 数据结构--二叉树--详解
  5. 交换机及路由器DHCP配置
  6. 学生HTML个人网页作业作品~个人主页博客网页设计制作(6个页面)~大学生个人网站作业模板~HTML简单个人网页制作...
  7. 2021全球程序员收入报告:字节跳动高级工程师跻身世界第5
  8. 在html中如何加入vb脚本,VB脚本编辑器该进详解
  9. 用valgrind 检测内存错误
  10. 智能语音AI机器人部署中的战斗机