mysql 怎么定义变量
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 怎么定义变量相关的知识,希望对你有一定的参考价值。
mysql> declare @t int;
为什么这会出错啊
DECLARE v_index INT;
定义一个 名称为 v_index 的变量, 类型为 INT
MYSQL 变量定义应该只能在 存储过程, 函数里面定义.
不像 Oracle / SQL Server , 一个 BEGIN / END 里面就可以定义/执行了。
mysql> DELIMITER //
mysql> CREATE PROCEDURE TestWhile()
-> BEGIN
-> DECLARE v_index INT;
->
-> SET v_index = 0;
->
-> WHILE v_index < 5 DO
-> SET v_index = v_index + 1;
-> SELECT v_index;
-> END WHILE;
->
-> END//
Query OK, 0 rows affected (0.00 sec) 参考技术A MySQL 变量存在的介质及意义:
MySQL 的变量存在于内存、以及配置文件中;
其中内存中的变量是在运行时生效,配置文件中的变量是在 mysqld 程序启动时加载到内存中;
MySQL 8 版本以前为了保证修改后的变量的值在 MySQL 运行时及 MySQL 重启后生效,此时你需要分别修改内存和配置文件中变量的值:
SET global/session 语句设置内存中全局/当前会话的变量的值,通过 Linux 命令⼿⼯修改配置⽂件中变量的值,此时你会发现,你的配置⽂件需要 通过 ps -ef | grep mysql 查看进程启动命令中带⼊的选项 --defaults-file,以确定配置⽂件,如果启动命令没有带⼊选项 --defaults-file,那么默认配置⽂件为 /etc/my.cnf ;
你会发现修改配置⽂件时,需要确定配置⽂件,以及修改配置⽂件,这个步骤其实蛮繁琐的,⽽且如果你⼀不小心写错了变量名或值,可能会直接导致启动 MySQL 失败,如果此时 你有其他策略依赖 MySQL 的启动/重启,那么这个 MySQL 启动失败可能⼜会导致你策略判断不符合预期,造成其他不好的后果,这可能是就是亚马逊飓风初始的那只蝴蝶的翅膀。
mysql存储过程中怎么在循环中取变量值???
我在存储过程里,定义了5个变量都是datetime类型:endTime1,endTime2,endTime3,endTime4,endTime5;
declare i int default 1;
我想在循环里取这5个endTime的值,然后insert表里,
WHILE i<=3 DO
insert into table values (endTime+i); // endTime+i 这是java的写法,请问mysql里有类似的写法么?有什么好办法取这几个变量吗?
set i=i+1;
END WHILE;
endTime+i 这是java的写法,请问mysql里有类似的写法么?有什么好办法取这几个变量的值?
有什么好办法么?
BEGIN
DECLARE V_I INT DEFAULT 0;
START TRANSACTION;
WHILE V_I<=5 DO
SET V_I=V_I+1;
SET @V=V_I;
SET @INSERTSTR=CONCAT('INSERT INTO TB_LOG(ID) VALUES(?)');
PREPARE STMT FROM @INSERTSTR;
EXECUTE STMT USING @V;
END WHILE;
DEALLOCATE PREPARE STMT;
COMMIT;
END;
与以上代码类似追问
你好,我这么写。运行的结果是个字符串。
我想v_insertStr的值为datetime类型的,
我想循环输出endTime1,endTime2,endTime3,endTime4的值。该怎么修改下呢?
以上是关于mysql 怎么定义变量的主要内容,如果未能解决你的问题,请参考以下文章