明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

mysql的用戶變量

[摘要]我覺得很悲哀,為什么看的人多,說的人少呢。是覺得太簡(jiǎn)單而不屑一顧呢?還是想留一小手呢?問題的提出 id=2131117有一個(gè)表,內(nèi)容如下idname 1 aaa 4 bbb 6 ccc 14 a1 ...
我覺得很悲哀,為什么看的人多,說的人少呢。
是覺得太簡(jiǎn)單而不屑一顧呢?還是想留一小手呢?

問題的提出 id=2131117
有一個(gè)表,內(nèi)容如下
idname
1 aaa
4 bbb
6 ccc
14 a1
15 a2
26 b1
怎樣做才能得到如下結(jié)果
id name p
1 aaa1
4 bbb2
6 ccc3
14 a1 4
15 a2 5
26 b1 6
又怎樣做,才能這樣?
namep
aaa aaa
bbb aaa bbb
ccc aaa bbb ccc
a1aaa bbb ccc a1
a2aaa bbb ccc a1 a2
b1aaa bbb ccc a1 a2 b1

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

你可以用SET句法設(shè)置一個(gè)變量:

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

你也可以用@variable:=expr句法在一個(gè)表達(dá)式中設(shè)置一個(gè)變量:

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);




標(biāo)簽:mysql的用戶變量