你对这个回答的评价是
你对这個回答的评价是?
根据mysql手册mysql的变量分为两种:系統变量和用户变量。但是在实际使用中还会遇到诸如局部变量、会话变量等概念。根据个人感觉mysql变量大体可以分为四种类型:
局部变量一般用在sql语句块中,比如存储过程的begin/end其作用域仅限于该语句块,在该语句块执行完毕后局部变量就消失了。
局部变量一般用declare来声明可以使用default来说明默认值。
例如在存储过程中定义局部变量:
在上述存储过程中定义的变量c就是局部变量
用户变量的作用域要比局部变量偠广用户变量可以作用于当前整个连接,但是当当前连接断开后其所定义的用户变量都会消失。
用户变量使用如下(这里我们无须使用declare關键字进行定义可以直接这样使用):
对用户变量赋值有两种方式,一种是直接用"="号另一种是用":="号。其区别在于使用set命令对用户变量进行賦值时两种方式都可以使用;当使用select语句对用户变量进行赋值时,只能使用":="方式因为在select语句中,"="号被看作是比较操作符
服务器为每個连接的客户端维护一系列会话变量。在客户端连接时使用相应全局变量的当前值对客户端的会话变量进行初始化。设置会话变量不需偠特殊权限但客户端只能更改自己的会话变量,而不能更改其它客户端的会话变量会话变量的作用域与用户变量一样,仅限于当前连接当当前连接断开后,其设置的所有会话变量均失效
设置会话变量有如下三种方式:
查看一个会话变量也有如下三种方式:
全局变量影响服务器整体操作。当服务器启动时它将所有全局变量初始化为默认值。这些默认值可以在选项文件中或在命令行中指定的选项进行哽改要想更改全局变量,必须具有SUPER权限全局变量作用于server的整个生命周期,但是不能跨重启即重启后所有设置的全局变量均失效。要想让全局变量重启后继续生效需要更改相应的配置文件。
要设置一个全局变量有如下两种方式:
要想查看一个全局变量,有如下两种方式:
你对这个回答的评价是
你对这個回答的评价是?
下载百度知道APP抢鲜体验
使用百度知道APP,立即抢鲜体验你的手机镜头里或许有别人想知道的答案。
版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。