mysql的使用者變數
來源:互聯網
上載者:User
mysql|變數 我覺得很悲哀,為什麼看的人多,說的人少呢。
是覺得太簡單而不屑一顧呢?還是想留一小手呢?
問題的提出 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);