例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语句内容请搜索
更多相关Mysql内容来自木庄网络博客
标签:Mysql
相关阅读 >>
更多相关阅读请进入《mysql》频道 >>

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