发布时间:2023-08-11 17:30
MySQL本质是一种编程语言
对所有用户客户端都有效
1、方式一
show variables [like \'pattern\'];
示例
mysql> show variables like \'autocommit\'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | ON | +---------------+-------+
2、方式二:
使用select查询变量的数据值
select @@变量名;
示例
select @@autocommit; +--------------+ | @@autocommit | +--------------+ | 1 | +--------------+
1、局部修改(会话级别)
-- 只针对当前客户端当次连接有效 set 变量名 = 值; -- eg: set autocommit = \'off\'; show variables like \'autocommit\';
2、全局修改
-- 所有客户端,都有效 set global 变量名 = 值; set @@global.变量名 = 值; -- eg: set global autocommit = \'off\';
注意,全局修改之后,重启客户端生效
也称为用户变量,设置的变量,只针对当前用户使用的客户端生效
-- 定义用户变量 set @变量名 = 值; set @age = 23;
mysql中没有比较符号 == ,使用的是 =;
为了避免分不清是赋值还是比较,赋值使用:=
set @变量名 := 值; set @name := \'Tom\';
mysql允许将数据从表中取出存储到变量中,只能是一行数据
-- 1、赋值且查看赋值过程 select @变量1 := 字段1, @变量2 := 字段2 from 表 where 条件 select @name := name, @age := age from my_student limit 1; +---------------+-------------+ | @name := name | @age := age | +---------------+-------------+ | 刘备 | 18 | +---------------+-------------+ --- 2、只赋值不看过程 select 字段1, 字段2 from 表 where 条件 into @变量1, @变量2; select name, age from my_student limit 1 into @name, @age;
查看变量
select @变量名 mysql> select @name, @age; +--------+------+ | @name | @age | +--------+------+ | 刘备 | 18 | +--------+------+
作用范围在begin到end语句块之间,在该语句块里设置的变量
声明语法
declare 变量名 数据类型 [属性];
变量能够使用的区域范围
declare 关键字声明 (结构体中使用:函数/存储过程/触发器)
declare关键字声明的变量没有任何符号修饰,就是普通字符串,如果再外部访问该变量,系统会自动认为是字段
用户定义的,使用@符号定义的变量,使用set关键字
会话作用域,当次连接有效只要再本连接中,任何地方都可以使用(可以在结构内容,也可以跨库)
会话变量可以再函数内部使用
set @name = \'张三\'; create function get_name() returns char(4) return @name; select get_name(); +------------+ | get_name() | +------------+ | 张三 | +------------+
会话变量可以跨库
use mydatabase2; mysql> select @name; +--------+ | @name | +--------+ | 张三 | +--------+
所有的客户端,所有的连接都有效,需要使用全局符号来定义
set global 变量名 = 值; set @@global.变量名 = 值;
通常,在sql编程的时候,不会使用自定义变量来控制全局,一般定义会话变量或者结构中使用局部变量来解决问题
到此这篇关于MySQL详细讲解变量variables的用法的文章就介绍到这了,更多相关MySQL variables内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
vue集成openlayers(vue+openlayers)加载geojson并实现点击弹窗教程
39.JavaScript中Promise的基本概念、使用方法,回调地狱规避、链式编程
Angular InjectionToken APP_INITIALIZER multi 标志位不同值的情况讨论
推荐收藏系列:一文理解JVM虚拟机(内存、垃圾回收、性能优化)解决面试中遇到问题(图解版)
【Pytorch】基于GRU和LSTM的时间序列数据预测实现
华为harmonyOS鸿蒙怎么读,了解HarmonyOS是如何形成独特字体系统!荣耀系列鸿蒙OS下月来?...