mysql的用戶變量

發表于:2007-07-14來源:作者:點擊數: 標簽:
我覺得很悲哀,為什么看的人多,說的人少呢。 是覺得太簡單而不屑一顧呢?還是想留一小手呢? 問題的提出 id=2131117 有一個表,內容如下 idname 1aaa 4bbb 6ccc 14a1 15a2 26b1 怎樣做才能得到如下結果 id name p 1 aaa1 4 bbb2 6 ccc3 14 a14 15 a25 26 b1
我覺得很悲哀,為什么看的人多,說的人少呢。
是覺得太簡單而不屑一顧呢?還是想留一小手呢?

問題的提出 id=2131117
有一個表,內容如下
id  name
1   aaa
4   bbb
6   ccc
14   a1
15   a2
26   b1
怎樣做才能得到如下結果
id name p
1 aaa  1
4 bbb  2
6 ccc  3
14 a1   4
15 a2   5
26 b1   6
又怎樣做,才能這樣?
name        p
aaa aaa
bbb aaa bbb
ccc aaa bbb ccc
a1  aaa bbb ccc a1
a2  aaa bbb ccc a1 a2
b1  aaa bbb ccc a1 a2 b1

MySQL支持線程特定的變量,用@variablename句法。一個變量名可以由當前字符集的數字字母字符和“_”、“$”和“.”組成。缺省字符集是ISO-8859-1 Latin1;這可以通過重新編譯MySQL改變。
變量不必被初始化。缺省地,他們包含NULL并能存儲整數、實數或一個字符串值。當線程退出時,對于一個線程的所有變量自動地被釋放。

你可以用SET句法設置一個變量:

SET @variable= { integer expression | real expression | string expression }
[,@variable= ...].

你也可以用@variable:=expr句法在一個表達式中設置一個變量:

select @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;
+----------------------+------+------+------+
| @t1:=(@t2:=1)+@t3:=4 | @t1  | @t2  | @t3  |
+----------------------+------+------+------+
|                    5 |    5 |    1 |    4 |
+----------------------+------+------+------+

問題的解決:
1、
$rs = mysql_query("set @t=0");
$rs = mysql_query("SELECT id,name,@t:=@t+1 as p FROM tbl_name");
mysql_result_all($rs);

2、
$rs = mysql_query("set @t=''");
$rs = mysql_query("SELECT name,@t:=concat(@t,' ',name) as p FROM tbl_name");
mysql_result_all($rs);

原文轉自:http://www.anti-gravitydesign.com

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97