mysql 语句 关于 符号 :=

select i.name, v.value, v.version, IF(i.item_id = @item, @rank := @rank+1, @rank := 1) rank, @item := i.item_id item_idfrom wap_setting_value v 
inner join wap_setting_item i using(item_id) ;

:= 是什么意思 是比较运算符吗?  

红色部分 可以这样写?


作者: wangqiang_lenovo   发布时间: 2011-05-18

变量赋值在SQL语句中要用:=

作者: WWWWA   发布时间: 2011-05-18

类似这种语法问题,最简单的方法就是到MYSQL的手册上看一下。 或者自己亲自到MYSQL中试一下。

引用
9.3. 用户变量
可以先在用户变量中保存值然后在以后引用它;这样可以将值从一个语句传递到另一个语句。用户变量与连接有关。也就是说,一个客户端定义的变量不能被其它客户端看到或使用。当客户端退出时,该客户端连接的所有变量将自动释放。

用户变量的形式为@var_name,其中变量名var_name可以由当前字符集的文字数字字符、‘.’、‘_’和‘$’组成。 默认字符集是cp1252 (Latin1)。可以用mysqld的--default-character-set选项更改字符集。参见5.10.1节,“数据和排序用字符集”。用户变量名对大小写不敏感。

设置用户变量的一个途径是执行SET语句:

SET @var_name = expr [, @var_name = expr] ...
对于SET,可以使用=或:=作为分配符。分配给每个变量的expr可以为整数、实数、字符串或者NULL值。

也可以用语句代替SET来为用户变量分配一个值。在这种情况下,分配符必须为:=而不能用=,因为在非SET语句中=被视为一个比较 操作符:

mysql> SET @t1=0, @t2=0, @t3=0;
mysql> SELECT @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;
+----------------------+------+------+------+
| @t1:=(@t2:=1)+@t3:=4 | @t1 | @t2 | @t3 |
+----------------------+------+------+------+
| 5 | 5 | 1 | 4 |
+----------------------+------+------+------+
用户变量可以用于表达式中。目前不包括明显需

作者: ACMAIN_CHM   发布时间: 2011-05-18

赋值 在select语句中要用:=

set语句:=或者=都可以

作者: rucypli   发布时间: 2011-05-18