nextval mysql_mysql实现nextVal功能
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功能相关推荐
- oracle nextval mysql_mysql中实现类似oracle中的nextval函数
我们知道mysql中是不支持sequence的,一般是建表的时间使这个字段自增. 如 create table table_name(id int auto_increment prima ...
- mysql 实现nextval_mysql实现nextVal功能
首先创建表: CREATE TABLE `sys_sequence` ( `NAME` varchar(50) NOT NULL, `CURRENT_VALUE` int(11) NOT NULL D ...
- oracle rpad mysql_Oracle生成不重复票号与LPAD,RPAD与NEXTVAL函数解析
SELECT TO_CHAR(SYSDATE,'YYMMDD')||LPAD(REFUNDSEQ.NEXTVAL,6,'0') AS RES_ORDER_NO FROM DUAL 该语句拼接 时间 与 ...
- 串的模式匹配、KMP算法、nextval数组求法
一.暴力匹配 #include <iostream> using namespace std; #define MAXLEN 255 typedef struct{char ch[MAXL ...
- 手算KMP匹配的Next值和Nextval值(转载)
KMP 算法我们有写好的函数帮我们计算 Next 数组的值和 Nextval 数组的值,但是如果是考试,那就只能自己来手算这两个数组了,这里分享一下我的计算方法吧. 计算前缀 Next[i] 的值: ...
- kmp有next和nextval的C语言,KMP模式匹配算法中next和nextval的求解(轉)
KMP算法相關 轉載自:http://blog.sina.com.cn/s/blog_85b0ae450101j2iy.html KMP算法由兩部分組成: 第一部分,計算模式串的next或nextva ...
- 数据结构-KMP手算next与nextval(全网最简单,包会)
手算next值与nextval,全网最简单,时间关系,就不手打了(考完研后又手打了一遍,与图片一致). 直接把笔记内容图片粘贴了,绝对最简单.有问题的话,下方评论. 方法1:引入了一个maxL,在计算 ...
- KMP算法,字符串匹配,next与nextval数组求解
目录 KMP算法简介 next数组手动求解过程 next数组求解(代码实现) 改进的KMP算法 手动求解nextval数组 nextval数组求解(代码实现) KMP算法简介 KMP算法是一种改进的字 ...
- nextval数组求解
nextval数组求解过程 为什么用nextval数组 nextval数组求解方式 一.模式串的下标从0开始,nextval数组求解方式详解: 代码实现 二.模式串的下标从1开始,nextval数组求 ...
最新文章
- 基于OpenCV实战:提取中心线
- Python 技术篇-用PIL库旋转图片、改变图像尺寸
- crt脚本怎么添加等待时间_secureCRT自动化脚本(之定时任务)
- hmr webpack 不编译_webpack HMR未加载更改
- php.c drcom,校园网绕过Drcom安装自动登录程序到路由器
- NYOJ题目 263 精挑细选
- Adobe_Audition消除人声
- 关于python安装scipy模块的问题
- qt 处理oracle事务,qt调用oracle存储过程,该怎么处理(2)
- MATLAB 距离函数及用法
- Android VLC 加载ass字幕乱码问题
- div+css网页html成品学生作业包含10个html页面——动漫主题海贼王
- android3d画廊自动切换,Android ViewPager打造3D画廊
- MySQL报错:The server quit without updating PID file 我的解决思路和方法
- Linux 基础资料
- 亲爱的波特兰——CJ麦科勒姆告别信
- java练习案例_Java版打字练习案例源码
- lan9252、lan9253和lan9254参数比较
- 02 C/C++创建tcl自定义命令
- 《GitHub详细教程》
热门文章
- 今天主要谈谈关于申请美国专利的一些问题
- 在视频海洋里徜徉的年轻人,618都是怎么选手机的?
- mysql add column_SQL Add Column
- 数据结构--二叉树--详解
- 交换机及路由器DHCP配置
- 学生HTML个人网页作业作品~个人主页博客网页设计制作(6个页面)~大学生个人网站作业模板~HTML简单个人网页制作...
- 2021全球程序员收入报告:字节跳动高级工程师跻身世界第5
- 在html中如何加入vb脚本,VB脚本编辑器该进详解
- 用valgrind 检测内存错误
- 智能语音AI机器人部署中的战斗机