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里有类似的写法么?有什么好办法取这几个变量的值?
有什么好办法么?

参考技术A CREATE PROCEDURE LOOPINSERT()
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 怎么定义变量的主要内容,如果未能解决你的问题,请参考以下文章

PHP function 里 怎么调用外部定义过的变量

mysql 变量设置问题

mysql 变量设置问题

mysql存储过程中怎么在循环中取变量值???

sqlsever怎么定义两个整数变量,并分别赋值,最后输出两

怎么用变量给mysql里int型字段赋值Null