1. 界说一个局部变量(在函数或存储进程中运用):
```sqlSET @variable_name = value;```
2. 界说一个用户界说的变量(在会话等级运用):
```sqlSET @variable_name = value;```
3. 界说一个会话变量(在当时会话中有用):
```sqlSET SESSION variable_name = value;```
4. 界说一个大局变量(在所有会话中有用):
```sqlSET GLOBAL variable_name = value;```
5. 运用 `SELECT ... INTO` 句子将查询成果赋值给变量:
```sqlSELECT column_name INTO @variable_name FROM table_name;```
6. 运用 `DECLARE` 句子在存储进程中界说变量:
```sqlDECLARE variable_name dataType ;```
7. 运用 `DECLARE ... CURSOR` 句子在存储进程中界说游标变量:
```sqlDECLARE cursor_name CURSOR FOR SELECT statement;```
8. 运用 `DECLARE ... HANDLER` 句子在存储进程中界说错误处理变量:
```sqlDECLARE CONTINUE HANDLER FOR condition_name statement;```
9. 运用 `DECLARE ... CONDITION` 句子在存储进程中界说条件变量:
```sqlDECLARE condition_name CONDITION FOR condition_value;```
10. 运用 `DECLARE ... SIGNAL` 句子在存储进程中界说信号变量:
```sqlDECLARE SIGNAL signal_name SET MESSAGE_TEXT = 'message';```
11. 运用 `DECLARE ... EXIT` 句子在存储进程中界说退出变量:
```sqlDECLARE EXIT HANDLER FOR condition_name statement;```
12. 运用 `DECLARE ... RESIGNAL` 句子在存储进程中从头宣布信号:
```sqlDECLARE RESIGNAL signal_name SET MESSAGE_TEXT = 'message';```
请注意,MySQL中的变量名通常以 `@` 符号最初,以差异于表列名。此外,变量的效果域取决于它们是在会话等级、大局等级、存储进程/函数中界说的,仍是经过 `DECLARE` 句子在存储进程中界说的。
MySQL变量概述
在MySQL数据库中,变量是一种用于存储和传递值的东西。变量能够存储各种类型的值,如数字、字符串、日期等,而且能够在SQL句子中进行引证和操作。MySQL中的变量分为用户界说变量和体系变量两大类。
用户界说变量
用户界说变量是暂时存储在SQL会话中的变量,能够在该会话的任何地方运用。这种类型的变量无需声明数据类型,由于MySQL会依据上下文主动揣度。
界说用户界说变量
用户界说的变量能够经过SET或:操作符来界说,如下所示:
SET @userName = 'Alice';
或许运用愈加简练的赋值办法:
SELECT @userAge := 30;
运用这种办法界说变量后,您能够在SQL查询中恣意运用这些变量,例如:
SELECT FROM Users WHERE Name = @userName AND Age = @userAge;
这种办法十分合适动态构建查询条件或传递参数。
局部变量
局部变量通常在编写存储进程时运用。与用户界说的变量不同,局部变量必须在运用前声明其类型。
界说局部变量
以下是在存储进程中界说局部变量的示例:
DELIMITER //
CREATE PROCEDURE GetUserDetails()
BEGIN
DECLARE userStatus INT;
-- 变量声明
SET userStatus = 1; -- 变量赋值
END //
DELIMITER ;
在这个比如中,咱们运用DECLARE关键字声明晰一个名为userStatus的局部变量,并指定了其数据类型为INT。咱们运用SET句子为该变量赋值。
用户界说变量的效果域
用户界说变量的效果域是当时衔接。这意味着在一个衔接中界说的变量只能在该衔接中运用。如果在另一个衔接中履行相同的SQL句子,将不会看到之前衔接中界说的变量。
体系变量
体系变量是MySQL服务器装备的一部分,用于操控MySQL的行为。体系变量能够在服务器启动时设置,也能够在运行时动态更改。
检查体系变量
能够运用SHOW VARIABLES句子来检查MySQL的体系变量。例如:
SHOW VARIABLES LIKE '%characterset%';
这将显现与字符集相关的体系变量。
设置体系变量
要设置体系变量,能够运用SET句子。例如:
SET global character_set_server = 'utf8mb4';
这条句子将大局设置字符集服务器为'utf8mb4'。
变量在存储进程中的运用
界说变量
在存储进程中界说变量,如下所示:
DECLARE varname [, varname] type [DEFAULT value];
为变量赋值
运用SET句子为变量赋值,如下所示:
SET varname = expr [, varname = expr] ...;
运用变量进行条件判别
在存储进程中,能够运用变量进行条件判别,如下所示:
IF varname THEN
-- 条件为真时履行的代码
ELSE
-- 条件为假时履行的代码
END IF;
MySQL变量是数据库操作中十分有用的东西,能够帮助您更灵敏地处理数据和履行查询。经过了解和运用用户界说变量和体系变量,您能够进步数据库操作的功率,并使您的应用程序愈加强健。