mysql用户变量与set语句示例详解


当前第2页 返回上一页

例1:

mysql> set @varA = 3, @varB = @varA;
mysql> select @varB;
+-------+
| @varB |
+-------+
|  2 |
+-------+

例2:

mysql> set @varA = 3; 
mysql> set @varB = @varA;
mysql> select @varB;            
+-------+
| @varB |
+-------+
|  3 |
+-------+
    

3.2 通过select的实例

相对set语句而言,使用select定义变量,会返回一个表格形式的结果。

mysql> select @var1:=1, @var2:='vartest', @var3:=abs(-2), @var4:=(select count(*) from mysql.user);
+----------+------------------+----------------+------------------------------------------+
| @var1:=1 | @var2:='vartest' | @var3:=abs(-2) | @var4:=(select count(*) from mysql.user) |
+----------+------------------+----------------+------------------------------------------+
|    1 | vartest     |       2 |                    25 |
+----------+------------------+----------------+------------------------------------------+
mysql> select @var1, @var2, @var3, @var4;
+-------+---------+-------+-------+
| @var1 | @var2  | @var3 | @var4 |
+-------+---------+-------+-------+
|   1 | vartest |   2 |  25 |
+-------+---------+-------+-------+
+-------+---------+-------+-------+
|   1 | vartest |   2 |  25 |
+-------+---------+-------+-------+

4 用户变量注意事项

4.1 用户变量用在where或having子句中,他们必须首先用另一条语句来定义,如下面例子,初次查询没有返回结果,先定以后在查询才有输出。

mysql> select @H:='localhost' from mysql.user where host = @H;
Empty set (0.00 sec)
mysql> select @H:='localhost';
+-----------------+
| @H:='localhost' |
+-----------------+
| localhost    |
+-----------------+
1 row in set (0.00 sec)
mysql> select @H:='localhost', user from mysql.user where host = @H;
+-----------------+-----------------+
| @H:='localhost' | user      |
+-----------------+-----------------+
| localhost    |         |
| localhost    | jesse      |
| localhost    | local      |
| localhost    | root      |
| localhost    | user_tab_update |
+-----------------+-----------------+

4.2 用户变量为session级别,当我们关闭客户端或退出登录时用户变量全部消失。如果想用就保存自定义的变量,需要自行创建一个表,将标量insert到表里。

4.3 用户变量名对大小写不敏感。

4.4 未定义的变量初始化是null。

5 补充知识:mysql语句do

在do语句中,使用了一个或多个标量表达式,mysql会一条一条的处理它们,但并不显示表达式的结果。例如我们可以调用函数执行后台的某些事情,而不需要看到其结果。

例如:

mysql> do sleep(5);
Query OK, 0 rows affected (5.00 sec)

总结

到此这篇关于mysql用户变量与set语句的文章就介绍到这了,更多相关mysql用户变量与set语句内容请搜索

更多SQL内容来自木庄网络博客


标签:SQL

返回前面的内容

相关阅读 >>

mysql系列之四 sql语法

mysql数据库索引的最左匹配原则

sqlserver进程死锁关闭的方法

自动定时备份sqlserver数据库的方法

mysql数据库jdbc编程详解流程

sql关系模型的知识梳理总结

mysql执行事务的语法与流程详解

mysql的select 学习笔记

sql max用法是什么

mysql多表查询详解下

更多相关阅读请进入《sql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...