mysql中如何定义变量
SELECT@myRight:=rgtFROMnested_categoryWHEREname='TELEVISIONS';UPDATEnested_categorySE...
SELECT @myRight := rgt FROM nested_category WHERE name = 'TELEVISIONS';
UPDATE nested_category SET rgt = rgt + 2 WHERE rgt > @myRight;
UPDATE nested_category SET lft = lft + 2 WHERE lft > @myRight;
mysql中能不能实现类似的功能,定义变量,然后再后面的sql语句中使用。谢谢各位了 展开
UPDATE nested_category SET rgt = rgt + 2 WHERE rgt > @myRight;
UPDATE nested_category SET lft = lft + 2 WHERE lft > @myRight;
mysql中能不能实现类似的功能,定义变量,然后再后面的sql语句中使用。谢谢各位了 展开
推荐于2018-03-26
展开全部
测试一下, 好像是可行的呀!
mysql> select @test := 1;
+------------+
| @test := 1 |
+------------+
| 1 |
+------------+
1 row in set (0.00 sec)
mysql> select * from test_main;
+----+-------+
| id | value |
+----+-------+
| 1 | ONE |
| 2 | TWO |
| 3 | THREE |
+----+-------+
3 rows in set (0.00 sec)
mysql> select * from test_main where id > @test;
+----+-------+
| id | value |
+----+-------+
| 2 | TWO |
| 3 | THREE |
+----+-------+
2 rows in set (0.00 sec)
展开全部
一、局部变量
局部变量一般用在sql语句块中,比如存储过程的begin/end。其作用域仅限于该语句块,在该语句块执行完毕后,局部变量就消失了。
局部变量一般用declare来声明,可以使用default来说明默认值。
二、用户变量
用户变量的作用域要比局部变量要广。用户变量可以作用于当前整个连接,但是当当前连接断开后,其所定义的用户变量都会消失。
用户变量使用如下(这里我们无须使用declare关键字进行定义,可以直接这样使用):
select @变量名
对用户变量赋值有两种方式,一种是直接用"="号,另一种是用":="号。其区别在于使用set命令对用户变量进行赋值时,两种方式都可以使用;当使用select语句对用户变量进行赋值时,只能使用":="方式,因为在select语句中,"="号被看作是比较操作符。
局部变量一般用在sql语句块中,比如存储过程的begin/end。其作用域仅限于该语句块,在该语句块执行完毕后,局部变量就消失了。
局部变量一般用declare来声明,可以使用default来说明默认值。
二、用户变量
用户变量的作用域要比局部变量要广。用户变量可以作用于当前整个连接,但是当当前连接断开后,其所定义的用户变量都会消失。
用户变量使用如下(这里我们无须使用declare关键字进行定义,可以直接这样使用):
select @变量名
对用户变量赋值有两种方式,一种是直接用"="号,另一种是用":="号。其区别在于使用set命令对用户变量进行赋值时,两种方式都可以使用;当使用select语句对用户变量进行赋值时,只能使用":="方式,因为在select语句中,"="号被看作是比较操作符。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2020-11-09 · MySQL开源数据库领先者
关注
展开全部
MySQL 变量存在的介质及意义:
MySQL 的变量存在于内存、以及配置文件中;
其中内存中的变量是在运行时生效,配置文件中的变量是在 mysqld 程序启动时加载到内存中;
MySQL 8 版本以前为了保证修改后的变量的值在 MySQL 运行时及 MySQL 重启后生效,此时你需要分别修改内存和配置文件中变量的值:
SET global/session 语句设置内存中全局/当前会话的变量的值,通过 Linux 命令⼿⼯修改配置⽂件中变量的值,此时你会发现,你的配置⽂件需要 通过 ps -ef | grep mysql 查看进程启动命令中带⼊的选项 --defaults-file,以确定配置⽂件,如果启动命令没有带⼊选项 --defaults-file,那么默认配置⽂件为 /etc/my.cnf ;
你会发现修改配置⽂件时,需要确定配置⽂件,以及修改配置⽂件,这个步骤其实蛮繁琐的,⽽且如果你⼀不小心写错了变量名或值,可能会直接导致启动 MySQL 失败,如果此时 你有其他策略依赖 MySQL 的启动/重启,那么这个 MySQL 启动失败可能⼜会导致你策略判断不符合预期,造成其他不好的后果,这可能是就是亚马逊飓风初始的那只蝴蝶的翅膀。
MySQL 的变量存在于内存、以及配置文件中;
其中内存中的变量是在运行时生效,配置文件中的变量是在 mysqld 程序启动时加载到内存中;
MySQL 8 版本以前为了保证修改后的变量的值在 MySQL 运行时及 MySQL 重启后生效,此时你需要分别修改内存和配置文件中变量的值:
SET global/session 语句设置内存中全局/当前会话的变量的值,通过 Linux 命令⼿⼯修改配置⽂件中变量的值,此时你会发现,你的配置⽂件需要 通过 ps -ef | grep mysql 查看进程启动命令中带⼊的选项 --defaults-file,以确定配置⽂件,如果启动命令没有带⼊选项 --defaults-file,那么默认配置⽂件为 /etc/my.cnf ;
你会发现修改配置⽂件时,需要确定配置⽂件,以及修改配置⽂件,这个步骤其实蛮繁琐的,⽽且如果你⼀不小心写错了变量名或值,可能会直接导致启动 MySQL 失败,如果此时 你有其他策略依赖 MySQL 的启动/重启,那么这个 MySQL 启动失败可能⼜会导致你策略判断不符合预期,造成其他不好的后果,这可能是就是亚马逊飓风初始的那只蝴蝶的翅膀。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |