本博客介绍一下MySQL中变量的用法和注意细节

@

一、用户变量

1.1、用户变量定义

MySQL官方手册里是将变量分为系统变量和用户变量的,用户变量就是在一个语句里加在用户自定义的变量,然后这个变量可以赋值给其它变量,或者在另外一个语句里调用等,本博客基于MySQL5.7版本,其它版本的还是具体参考官方手册

【拓展】:

MySQL官方手册里是将变量分为系统变量和用户变量的,不过有些地方也将变量按照用法分为:1、临时变量(@符号的情况,也就是mysql手册介绍的用户变量);2、局部变量(declare方式);3、会话变量;4、全局变量(也就是系统变量),其实分类只是为了方便记录学习,重点是掌握用法原理就可以,因为局部变量和会话变量用的比较少,所以简单介绍一下

一、declare声明变量(局部变量)

declare声明变量:declare声明关键字可以用于定义变量,一般用于存储过程或者自定义函数里

a)、declare声明变量

用法:声明一个v1变量,定义为int类型,默认值为0;

declare v1 INT default 0;

b)、declare变量使用

声明后变量一般是在存储过程或者自定义里的,所以是写在begin和end关键字之间的,外面的不能直接定义,然后调用,所以declare也被称之为局部变量

二、session会话变量

session会话变量用的比较少,不过有个特性是和@临时变量是一致的,就是关闭会话,或者说关闭数据库连接的时候,变量是会失效的

1.2、用户变量用法

a)、设置用户变量

SET @var_name = expr [, @var_name = expr] ...

其实就是直接用关键字set就可以,例子

set @v1 =: 'test';

或者直接省略冒号也是可以的,不过建议还是加上,以免有些情况获取不到数据

set @v1 ='test';

其实,可以不用set关键字

select @v1 := 'test';

查询时候直接赋值也是可以的,看起来@符合的用法比较灵活,并没有那么多约束。所以有些地方是将用这种用法称之为临时变量

b)、查询用户变量

查询变量:

select @[变量名];

比如刚才的@v1临时变量

select @v1;

备注:使用@符号的这种用法,在数据库连接的时候是有效的,当你关闭数据库连接的时候,变量值是会被置为Null值的,所以也是这种@符号用法set的变量被称之为临时变量的原因

【用法注意事项】:

  • 变量名称

    用户变量名称不区分大小写。名称的最大长度为64个字符,假如超过会报错:
Error Code: 3061
User variable name ${变量名} is illegal
  • 变量分配值

    用户变量分配值:整数,十进制,浮点,二进制或非二进制字符串或NULL值,如果为日期类型是不支持的

  • 分配给用户变量的十六进制或位值被视为二进制字符串。要将十六进制或位值作为数字分配给用户变量,可以使用加0或使用CAST(... AS UNSIGNED)的方式

    例子来自mysql官方手册

mysql> SET @v1 = X'41';
mysql> SET @v2 = X'41'+0;
mysql> SET @v3 = CAST(X'41' AS UNSIGNED);
mysql> SELECT @v1, @v2, @v3;
+------+------+------+
| @v1 | @v2 | @v3 |
+------+------+------+
| A | 65 | 65 |
+------+------+------+
mysql> SET @v1 = b'1000001';
mysql> SET @v2 = b'1000001'+0;
mysql> SET @v3 = CAST(b'1000001' AS UNSIGNED);
mysql> SELECT @v1, @v2, @v3;
+------+------+------+
| @v1 | @v2 | @v3 |
+------+------+------+
| A | 65 | 65 |
+------+------+------+
  • 变量不要连续使用

    这种情况在手册已经指出来了,如图脚本:
mysql> SET @a:='test';
mysql> SELECT @a,(@a:=20)

可以查询出来,发现第一个变量还是'test'字符串,而第二个字符串却是另外一个值

【用户变量案例】:

介绍一下,变量来做类似oracle rownum的用法

oracle原版写法:

select * from (select id,name from t) where rownum <![CDATA[<=]]> to_number(num);

mysql改写后的SQL:

SELECT
*
FROM
(SELECT
tb.*,
@rownum := @rownum + 1 AS rownum
FROM
(SELECT
id,
NAME
FROM
t) tb,
(SELECT
@rownum := 0) r) AS t
WHERE rownum <= CAST(num AS SIGNED INTEGER) ;

二、系统变量

2.1 系统变量简单介绍

系统变量也称之为全局变量,系统变量是mysql的一些系统变量参数,一般不要修改,特别是生产环境

2.2 系统变量用法简介

用户变量的用法是用@符号,系统变量查询是用@@符号,参数有很多,比如:

  • 查询MySQL目录
SELECT @@basedir;

  • 查看数据目录
select @@datadir;

MySQL变量介绍和用法简介的更多相关文章

  1. MySQL基础之自连接用法简介

    MySQL系列之自连接简介,MySQL自连接操作,没有特定的关键字,所谓自连接指的是同一个表不同实例之间的join操作 引用https://www.w3resource.com的图示: 特征: 自连接 ...

  2. Oracle SQL调优之绑定变量用法简介

    目录 一.SQL执行过程简介 二.绑定变量典型用法 2.1.在SQL中绑定变量 2.2.在PL/SQL中使用绑定变量 2.3.PL/SQL批量绑定变量 2.4.Java代码里使用绑定变量 最近在看&l ...

  3. MySQL各类日志文件相关变量介绍

    文章转自:http://www.ywnds.com/?p=3721 MySQL各类日志文件相关变量介绍 查询所有日志的变量   1 mysql> show global variables li ...

  4. MySQL基础之STRAIGHT JOIN用法简介

    MySQL基础之STRAIGHT JOIN用法简介 引用mysql官方手册的说法: STRAIGHT_JOIN is similar to JOIN, except that the left tab ...

  5. Postman用法简介

    转自:http://blog.csdn.net/flowerspring/article/details/52774399 Postman用法简介 转载 2016年10月10日 09:04:10 10 ...

  6. 第二十七章 ansible变量介绍

    一.ansible变量介绍 1.概念 变量提供了便捷的方式来管理Ansible playbook的每一个项目中的动态值,比如nginx-1.6.3这个软件包的版本,在其它地方或许会反复使用,那么如果讲 ...

  7. mysql中FIND_IN_SET函数用法

    本篇文章主要介绍mysql中FIND_IN_SET函数用法,用来精确查询字段中以逗号分隔的数据 以及其与 like 和 in 的区别 1.问题发现 之前在做工作任务时有这么一个需求:需要用接口所传的服 ...

  8. 十周周末总结 MySQL的介绍与使用

    python 十周周末总结 MySQL的介绍与使用 MySQL字符编码与配置文件 查看数据库的基本信息(用户,字符编码) /s windos下MySQL默认的配置文件 my_default.ini 修 ...

  9. IOS NSInvocation用法简介

    IOS NSInvocation用法简介 2012-10-25 19:59 来源:博客园 作者:csj007523 字号:T|T [摘要]在 iOS中可以直接调用某个对象的消息方式有两种,其中一种就是 ...

随机推荐

  1. 手机投屏工具与HOSTS切换工具

    ApowerMirror windows -->switchhosts

  2. Springcloud 配置 | 史上最全,一文全懂

    Springcloud 高并发 配置 (一文全懂) 疯狂创客圈 Java 高并发[ 亿级流量聊天室实战]实战系列之15 [博客园总入口 ] 前言 疯狂创客圈(笔者尼恩创建的高并发研习社群)Spring ...

  3. 将vue项目部署在Linux的Nginx下,并设置为局域网内访问

    1. 下载 wget http://nginx.org/download/nginx-1.12.2.tar.gz 2. 解压缩 tar -zxvf linux-nginx-1.12.2.tar.gz ...

  4. mysql中的事务隔离级别

    事务是逻辑上的一组操作,要么都执行,要么都不执行. 事务最经典的.经常被拿出来说的例子就是转账了.假如小花要给小白转账1000元,这个转账会涉及到两个关键操作就是:将小花的余额-1000,将小白的余额 ...

  5. Linux系统:centos7下搭建ZooKeeper3.4中间件,常用命令总结

    本文源码:GitHub·点这里 || GitEE·点这里 一.下载解压 1.Zookeeper简介 Zookeeper 作为一个分布式的服务框架,主要用来解决分布式集群中应用系统的一致性问题,它能提供 ...

  6. css实现左右两个div等高

    提出问题: 现在有两个div,但是两个div里面内容多少不确定,可能左边多,可能右边多,css要如何设置可以保证左右两边的div等高呢? 解决方案: 每个div使用display:table-cell ...

  7. .NET Core 实现 腾讯云云解析简单客户端

    一.说明 腾讯云的.NET SDK虽然非常强大,但是对他的产品支持不是很完全,域名的云解析就没有SDK,所以自己写了一个,初衷是用来做动态DNS的,也准备接入多个云厂商,但是我自己本身仅仅只有腾讯云这 ...

  8. 用Python制作的一本道生成器,最后笑喷了!

    今天皮一下,众所周知,一本道是一本正经的胡说八道的简称,想必写过议论文的小伙伴,都知道引经据典是议论文高分必备,套上名人的话更加具有说服力是语文老师必教的知识点. 所以呢,今天介绍的这个生成器就走的是 ...

  9. linux中服务(service)管理

    一.介绍 服务(service) 本质就是进程,但是是运行在后台的,通常都会监听某个端口,等待其它程序的请求,比如(mysql , sshd 防火墙等),因此我们又称为守护进程,是Linux 中非常重 ...

  10. git如何合并远程2个分支

    1,先检出项目到一个文件夹git clone 2,你检出的项目默认是master,所以现在要查看远程全部分支git branch -a * master remotes/origin/HEAD -&g ...