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变量是数据库操作中十分有用的东西,能够帮助您更灵敏地处理数据和履行查询。经过了解和运用用户界说变量和体系变量,您能够进步数据库操作的功率,并使您的应用程序愈加强健。