您的位置:首页 > 教程 > Mysql/MariaDB > MySQL详细讲解变量variables的用法

MySQL详细讲解变量variables的用法

2022-06-18 12:10:16 来源:易采站长站 作者:

MySQL详细讲解变量variables的用法

目录
变量 variables1、系统变量1.1、查看系统变量1.2、修改系统变量2、会话变量3、局部变量4、变量作用域4.1、局部作用域4.2、会话作用域4.3、全局作用域

3YQ站长之家-易采站长站-Easck.Com

变量>

MySQL本质是一种编程语言3YQ站长之家-易采站长站-Easck.Com

3YQ站长之家-易采站长站-Easck.Com

1、系统变量

对所有用户客户端都有效3YQ站长之家-易采站长站-Easck.Com

3YQ站长之家-易采站长站-Easck.Com

1.1、查看系统变量

1、方式一3YQ站长之家-易采站长站-Easck.Com

show variables [like 'pattern'];

示例3YQ站长之家-易采站长站-Easck.Com

mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit    | ON    |
+---------------+-------+

2、方式二:3YQ站长之家-易采站长站-Easck.Com

使用select查询变量的数据值3YQ站长之家-易采站长站-Easck.Com

select @@变量名;

示例3YQ站长之家-易采站长站-Easck.Com

select @@autocommit;
+--------------+
| @@autocommit |
+--------------+
|            1 |
+--------------+

3YQ站长之家-易采站长站-Easck.Com

1.2、修改系统变量

1、局部修改(会话级别)3YQ站长之家-易采站长站-Easck.Com

-- 只针对当前客户端当次连接有效
set 变量名 = 值;
-- eg:
set autocommit = 'off';
show variables like 'autocommit';

2、全局修改3YQ站长之家-易采站长站-Easck.Com

-- 所有客户端,都有效
set global 变量名 = 值;
set @@global.变量名 = 值;
-- eg:
set global autocommit = 'off';

注意,全局修改之后,重启客户端生效3YQ站长之家-易采站长站-Easck.Com

3YQ站长之家-易采站长站-Easck.Com

2、会话变量

也称为用户变量,设置的变量,只针对当前用户使用的客户端生效3YQ站长之家-易采站长站-Easck.Com

-- 定义用户变量
set @变量名 = 值;
set @age = 23;

mysql中没有比较符号 == ,使用的是 =;3YQ站长之家-易采站长站-Easck.Com
为了避免分不清是赋值还是比较,赋值使用:=3YQ站长之家-易采站长站-Easck.Com

set @变量名 := 值;
set @name := 'Tom';

mysql允许将数据从表中取出存储到变量中,只能是一行数据3YQ站长之家-易采站长站-Easck.Com

-- 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;

查看变量3YQ站长之家-易采站长站-Easck.Com

select @变量名
mysql> select @name, @age;
+--------+------+
| @name  | @age |
+--------+------+
| 刘备   |   18 |
+--------+------+

3YQ站长之家-易采站长站-Easck.Com

3、局部变量

作用范围在begin到end语句块之间,在该语句块里设置的变量3YQ站长之家-易采站长站-Easck.Com

    declare语句用于定义局部变量局部变量>

    声明语法3YQ站长之家-易采站长站-Easck.Com

    declare 变量名 数据类型 [属性];
    

    3YQ站长之家-易采站长站-Easck.Com

    4、变量作用域

    变量能够使用的区域范围3YQ站长之家-易采站长站-Easck.Com

    3YQ站长之家-易采站长站-Easck.Com

    4.1、局部作用域

    declare>

    declare关键字声明的变量没有任何符号修饰,就是普通字符串,如果再外部访问该变量,系统会自动认为是字段3YQ站长之家-易采站长站-Easck.Com

    3YQ站长之家-易采站长站-Easck.Com

    4.2、会话作用域

    用户定义的,使用@符号定义的变量,使用set关键字3YQ站长之家-易采站长站-Easck.Com

    会话作用域,当次连接有效只要再本连接中,任何地方都可以使用(可以在结构内容,也可以跨库)3YQ站长之家-易采站长站-Easck.Com

    会话变量可以再函数内部使用3YQ站长之家-易采站长站-Easck.Com

    set @name = '张三';
    create function get_name() returns char(4)
    return @name;
    select get_name();
    +------------+
    | get_name() |
    +------------+
    | 张三       |
    +------------+

    会话变量可以跨库3YQ站长之家-易采站长站-Easck.Com

    use mydatabase2;
    mysql> select @name;
    +--------+
    | @name  |
    +--------+
    | 张三   |
    +--------+ 

    3YQ站长之家-易采站长站-Easck.Com

    4.3、全局作用域

    所有的客户端,所有的连接都有效,需要使用全局符号来定义3YQ站长之家-易采站长站-Easck.Com

    set global 变量名 = 值;
    set @@global.变量名 = 值;
    

    通常,在sql编程的时候,不会使用自定义变量来控制全局,一般定义会话变量或者结构中使用局部变量来解决问题3YQ站长之家-易采站长站-Easck.Com

    到此这篇关于MySQL详细讲解变量variables的用法的文章就介绍到这了,更多相关MySQL variables内容请搜索易采站长站以前的文章或继续浏览下面的相关文章希望大家以后多多支持易采站长站!3YQ站长之家-易采站长站-Easck.Com

    如有侵权,请联系QQ:279390809 电话:15144810328

相关文章

  • mysql 5.7.30安装配置方法图文教程

    mysql 5.7.30安装配置方法图文教程

    之前把服务器里面的MySQL卸了重装,安装mysql时未做总结,换新电脑,补上安装记录,安装的时候,找了些网友的安装记录,发现好多坑 截个图,作为笔记,也正好留给需要的朋友们。
    2019-01-03
  • MySQL5.6免安装版环境配置图文教程

    MySQL5.6免安装版环境配置图文教程

    MySQL是一个小巧玲珑但功能强大的数据库,目前十分流行。但是官网给出的安装包有两种格式,一个是msi格式,一个是zip格式的。很多人下了zip格式的解压发现没有setup.exe,面对一堆文
    2019-01-04
  • Linux下安装mysql-8.0.20的教程详解

    Linux下安装mysql-8.0.20的教程详解

    ** Linux下安装mysql-8.0.20 ** 环境介绍 操作系统:CentOS 7 mysql下载地址:https://dev.mysql.com/downloads/mysql/ 下载版本:mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz 卸载mysql 查看是否安装过mysql,命令:fin
    2020-05-24
  • linux环境下安装mysql数据库的详细教程

    linux环境下安装mysql数据库的详细教程

    1.安装数据库 1)yum -y install mysql-server(简单) yum命令自动从网上寻找mysql服务资源,下载至本地并完成安装 2)也可以自己在网上下载mysql服务,通过xftp传输至Linux系统,自己安装(一般安
    2020-06-20
  • MySQL8.0.20安装教程及其安装问题详细教程

    MySQL8.0.20安装教程及其安装问题详细教程

    原文地址:https://blog.csdn.net/m0_46579864/article/details/105981304 官网下载MySQL的安装包 1.下载链接如下: MySQL8.0.20版本 https://dev.mysql.com/doc/relnotes/mysql/8.0/en/news-8-0-20.html 其他版本:MySQL8.0.16版本
    2020-05-10
  • MySQL对数据库操作(创建、选择、删除)

    MySQL对数据库操作(创建、选择、删除)

    MySQL 创建数据库 我们可以在登陆 MySQL 服务后,使用 create 命令创建数据库,语法如下: CREATE DATABASE 数据库名; 以下命令简单的演示了创建数据库的过程,数据名为 RUNOOB: [root@host]# mysql
    2020-07-01
  • Linux系统MySQL8.0.19快速安装配置教程图解

    Linux系统MySQL8.0.19快速安装配置教程图解

    一、环境介绍 Linux系统使用yum安装MySQL需要从网上下载MySQL的一系列组件,这个过程非常耗时且有下载中断的可能,如果想要快速安装MySQL,可以先在网上将MySQL的离线包下载下来传到系
    2020-02-27
  • mysql 加了 skip-name-resolve不能链接数据库问题的解决方法

    mysql 加了 skip-name-resolve不能链接数据库问题的解决方法

    mysql 加了 skip-name-resolve不能链接的问题, 要确认 MySql 是否采用过主机名的授权 在 MySql Server 的配置文件 My.ini 中,增加如下两行: [mysqld] skip-name-resolve 它将禁止 MySql Server 对外部连接进
    2019-01-04