- MySQL 基础
- MySQL - 首页
- MySQL - 简介
- MySQL - 特性
- MySQL - 版本
- MySQL - 变量
- MySQL - 安装
- MySQL - 管理
- MySQL - PHP 语法
- MySQL - Node.js 语法
- MySQL - Java 语法
- MySQL - Python 语法
- MySQL - 连接
- MySQL - Workbench
- MySQL 数据库
- MySQL - 创建数据库
- MySQL - 删除数据库
- MySQL - 选择数据库
- MySQL - 显示数据库
- MySQL - 复制数据库
- MySQL - 数据库导出
- MySQL - 数据库导入
- MySQL - 数据库信息
- MySQL 用户
- MySQL - 创建用户
- MySQL - 删除用户
- MySQL - 显示用户
- MySQL - 修改密码
- MySQL - 授予权限
- MySQL - 显示权限
- MySQL - 收回权限
- MySQL - 锁定用户账户
- MySQL - 解锁用户账户
- MySQL 表
- MySQL - 创建表
- MySQL - 显示表
- MySQL - 修改表
- MySQL - 重命名表
- MySQL - 克隆表
- MySQL - 截断表
- MySQL - 临时表
- MySQL - 修复表
- MySQL - 描述表
- MySQL - 添加/删除列
- MySQL - 显示列
- MySQL - 重命名列
- MySQL - 表锁定
- MySQL - 删除表
- MySQL - 派生表
- MySQL 查询
- MySQL - 查询
- MySQL - 约束
- MySQL - 插入查询
- MySQL - 选择查询
- MySQL - 更新查询
- MySQL - 删除查询
- MySQL - 替换查询
- MySQL - 插入忽略
- MySQL - 插入重复键更新
- MySQL - 将选择插入
- MySQL 运算符和子句
- MySQL - WHERE 子句
- MySQL - LIMIT 子句
- MySQL - DISTINCT 子句
- MySQL - ORDER BY 子句
- MySQL - GROUP BY 子句
- MySQL - HAVING 子句
- MySQL - AND 运算符
- MySQL - OR 运算符
- MySQL - LIKE 运算符
- MySQL - IN 运算符
- MySQL - ANY 运算符
- MySQL - EXISTS 运算符
- MySQL - NOT 运算符
- MySQL - 不等于运算符
- MySQL - IS NULL 运算符
- MySQL - IS NOT NULL 运算符
- MySQL - BETWEEN 运算符
- MySQL - UNION 运算符
- MySQL - UNION 与 UNION ALL
- MySQL - MINUS 运算符
- MySQL - INTERSECT 运算符
- MySQL - INTERVAL 运算符
- MySQL 连接
- MySQL - 使用连接
- MySQL - INNER JOIN
- MySQL - LEFT JOIN
- MySQL - RIGHT JOIN
- MySQL - CROSS JOIN
- MySQL - FULL JOIN
- MySQL - 自连接
- MySQL - 删除连接
- MySQL - 更新连接
- MySQL - UNION 与 JOIN
- MySQL 触发器
- MySQL - 触发器
- MySQL - 创建触发器
- MySQL - 显示触发器
- MySQL - 删除触发器
- MySQL - 插入前触发器
- MySQL - 插入后触发器
- MySQL - 更新前触发器
- MySQL - 更新后触发器
- MySQL - 删除前触发器
- MySQL - 删除后触发器
- MySQL 数据类型
- MySQL - 数据类型
- MySQL - VARCHAR
- MySQL - BOOLEAN
- MySQL - ENUM
- MySQL - DECIMAL
- MySQL - INT
- MySQL - FLOAT
- MySQL - BIT
- MySQL - TINYINT
- MySQL - BLOB
- MySQL - SET
- MySQL 正则表达式
- MySQL - 正则表达式
- MySQL - RLIKE 运算符
- MySQL - NOT LIKE 运算符
- MySQL - NOT REGEXP 运算符
- MySQL - regexp_instr() 函数
- MySQL - regexp_like() 函数
- MySQL - regexp_replace() 函数
- MySQL - regexp_substr() 函数
- MySQL 函数和运算符
- MySQL - 日期和时间函数
- MySQL - 算术运算符
- MySQL - 数值函数
- MySQL - 字符串函数
- MySQL - 聚合函数
- MySQL 其他概念
- MySQL - NULL 值
- MySQL - 事务
- MySQL - 使用序列
- MySQL - 处理重复项
- MySQL - SQL 注入
- MySQL - 子查询
- MySQL - 注释
- MySQL - 检查约束
- MySQL - 存储引擎
- MySQL - 将表导出到 CSV 文件
- MySQL - 将 CSV 文件导入数据库
- MySQL - UUID
- MySQL - 公共表表达式
- MySQL - ON DELETE CASCADE
- MySQL - Upsert
- MySQL - 水平分区
- MySQL - 垂直分区
- MySQL - 游标
- MySQL - 存储函数
- MySQL - 信号
- MySQL - 重新发送信号
- MySQL - 字符集
- MySQL - 校对规则
- MySQL - 通配符
- MySQL - 别名
- MySQL - ROLLUP
- MySQL - 当天日期
- MySQL - 字面量
- MySQL - 存储过程
- MySQL - EXPLAIN
- MySQL - JSON
- MySQL - 标准差
- MySQL - 查找重复记录
- MySQL - 删除重复记录
- MySQL - 选择随机记录
- MySQL - SHOW PROCESSLIST
- MySQL - 更改列类型
- MySQL - 重置自动递增
- MySQL - COALESCE() 函数
- MySQL 有用资源
- MySQL - 有用函数
- MySQL - 语句参考
- MySQL - 快速指南
- MySQL - 有用资源
- MySQL - 讨论
MySQL - 变量
通常,变量是在程序中存储某些信息的容器。变量的值可以根据需要更改多次。每个变量都有一个数据类型,指定我们可以存储在其中的数据类型,例如整数、字符串、浮点数等。
在某些编程语言(如 Java、C、C++ 等)中,我们需要在为变量赋值之前声明变量的数据类型。
在像 Python 这样的语言中,变量的数据类型是根据分配给它的值推断出来的。无需单独声明数据类型。
在 MySQL 中,无需声明数据类型,我们可以使用 SET 语句简单地定义一个带有值的变量。
MySQL 中的变量
变量的主要目的是标记一个或多个内存位置并在其中存储数据,以便可以在整个程序中使用它。
我们用来声明和定义变量的字符称为字面量,字面量可以是除特殊字符、数字和保留关键字之外的任何内容。
在 MySQL 中,有三种类型的变量。下面描述了相同的内容:
用户定义变量
局部变量
系统变量
用户定义变量
用户定义变量允许我们在一个语句中存储一个值,然后在另一个语句中引用它。为此,MySQL 提供了 SET 和 SELECT 命令来声明变量。这些变量名将以符号“@”作为前缀。我们可以根据情况使用 = 或 := 符号。用户定义的数据类型可以是以下任何一种:整数、十进制、布尔值等。
语法
以下是使用 SET 语句在 MySQL 中声明用户定义变量的语法:
SELECT @variable_name = value
示例
在以下查询中,我们使用 SET 语句为变量赋值,如下所示:
SET @Name = 'Michael';
使用 SELECT 语句,我们可以显示 @name 变量的值:
SELECT @Name;
输出
上面查询的输出如下所示:
@Name |
---|
Michael |
示例
在这里,我们使用 SELECT 语句为变量赋值:
SELECT @test := 10;
输出
执行给定查询后,输出将显示如下:
@test := 10 |
---|
10 |
示例
让我们使用以下查询创建一个名为 CUSTOMERS 的表:
CREATE TABLE CUSTOMERS( ID INT AUTO_INCREMENT PRIMARY KEY, NAME VARCHAR(20) NOT NULL, AGE INT NOT NULL, ADDRESS CHAR (25), SALARY DECIMAL (18, 2) );
现在,让我们使用 INSERT INTO 语句将值插入到上面创建的表中:
INSERT INTO CUSTOMERS (NAME, AGE, ADDRESS, SALARY) VALUES ('Ramesh', 32, 'Ahmedabad', 2000.00), ('Khilan', 25, 'Delhi', 1500.00), ('Kaushik', 23, 'Kota', 2000.00), ('Chaitali', 25, 'Mumbai', 6500.00), ('Hardik', 27, 'Bhopal', 8500.00), ('Komal', 22, 'Hyderabad', 4500.00), ('Muffy', 24, 'Indore', 10000.00);
CUSTOMERS 表创建如下:
ID | NAME | AGE | ADDRESS | SALARY |
---|---|---|---|---|
1 | Ramesh | 32 | Ahmedabad | 2000.00 |
2 | Khilan | 25 | Delhi | 1500.00 |
3 | Kaushik | 23 | Kota | 2000.00 |
4 | Chaitali | 25 | Mumbai | 6500.00 |
5 | Hardik | 27 | Bhopal | 8500.00 |
6 | Komal | 22 | Hyderabad | 4500.00 |
7 | Muffy | 24 | Indore | 10000.00 |
现在,让我们使用 SELECT 语句声明一个名为 @max_salary 的变量,以显示 CUSTOMERS 表中的最大工资值:
SELECT @max_salary := MAX(salary) FROM CUSTOMERS;
然后,我们将选择表中工资等于@max_salary 变量的记录:
SELECT * FROM CUSTOMERS WHERE SALARY = @max_salary;
输出
上面查询的输出如下所示:
ID | NAME | AGE | ADDRESS | SALARY |
---|---|---|---|---|
7 | Muffy | 24 | Indore | 10000.00 |
局部变量
可以使用DECLARE 关键字声明 MySQL 局部变量。当我们声明局部变量时,不会使用 @ 符号作为前缀。此变量是强类型变量,这意味着我们绝对需要声明数据类型。
可以在声明变量时使用 MySQL DEFAULT 关键字来设置变量的默认值。这是一个可选参数,如果我们不定义它,则初始值将为NULL。
语法
以下是 MySQL 中声明局部变量的语法:
DECLARE variable_name1, variabale_name2, ... data_type [DEFAULT default_value];
示例
在下面的示例中,我们在存储过程中使用 DECLARE 语句。
DELIMITER // CREATE PROCEDURE salaries() BEGIN DECLARE Ramesh INT; DECLARE Khilan INT DEFAULT 30000; DECLARE Kaushik INT; DECLARE Chaitali INT; DECLARE Total INT; SET Ramesh = 20000; SET Kaushik = 25000; SET Chaitali = 29000; SET Total = Ramesh+Khilan+Kaushik+Chaitali; SELECT Total,Ramesh,Khilan,Kaushik,Chaitali; END //
现在,让我们使用以下查询调用存储过程:
CALL salaries() //;
输出
以下是输出:
总数 | Ramesh | Khilan | Kaushik | Chaitali |
---|---|---|---|---|
104000 | 20000 | 30000 | 25000 | 29000 |
系统变量
MySQL **系统变量**是由 MySQL 预定义的。这些变量包含我们需要的数据,以便与数据库一起工作。每个 MySQL 系统变量都有一个默认值。
MySQL 中的 SET 命令可以在运行时用于动态更改系统变量的值。
SHOW VARIABLES 命令有两个可用的变量作用域修饰符。它们是 GLOBAL 和 SESSION。
GLOBAL 变量在整个生命周期内都处于活动状态。
SESSION 变量仅在当前会话中可用。
以下是显示 MySQL 中所有系统变量的命令:
SHOW [GLOBAL | SESSION] VARIABLES;
示例
在下面的示例中,让我们使用 SHOW VARIABLES 查询显示现有的全局系统变量:
SHOW VARIABLES LIKE '%table%';
变量以如下表格式显示:
变量名 | 值 |
---|---|
big_tables | OFF |
default_table_encryption | OFF |
innodb_file_per_table | ON |
innodb_ft_aux_table | |
innodb_ft_server_stopword_table | |
innodb_ft_user_stopword_table | |
innodb_table_locks | ON |
innodb_temp_tablespaces_dir | .\#innodb_temp\ |
innodb_undo_tablespaces | 2 |
innodb_validate_tablespace_paths | ON |
lower_case_table_names | 1 |
max_heap_table_size | 16777216 |
old_alter_table | OFF |
performance_schema_max_table_handles | -1 |
performance_schema_max_table_instances | -1 |
performance_schema_max_table_lock_stat | -1 |
show_create_table_skip_secondary_engine | OFF |
show_create_table_verbosity | OFF |
table_definition_cache | 2000 |
table_encryption_privilege_check | OFF |
table_open_cache | 4000 |
table_open_cache_instances | 16 |
tablespace_definition_cache | 256 |
temptable_max_mmap | 1073741824 |
temptable_max_ram | 1073741824 |
temptable_use_mmap | ON |
tmp_table_size | 99614720 |
updatable_views_with_limit | YES |
现在,使用下面的查询,我们将获取 MySQL "key_buffer_size" 变量的当前值:
SELECT @@key_buffer_size;
输出
以下是上述查询的输出:
@@key_buffer_size |
---|
8388608 |