使用php将mysql表数据转换为字符串

时间:2012-01-09 08:08:19

标签: php mysql

假设我有一个如下的mysql表:

     id value
     1   01
     2   03
     3   02
     4   15
     5   05
     6   04
     7   06
     8   10
     9   07
     10  09
     11  08
     12  11
     13  12
     14  14
     15  13
     16  16

如何将它们转换为这样的字符串:

  01,03,02,15|05,04,06,10|07,09,08,11|12,14,13,16

任何帮助将不胜感激,谢谢!

2 个答案:

答案 0 :(得分:1)

$result = "SELECT value FROM `your_table` ORDER BY id ASC";

$i = 0;
$string = '';
while($row = mysql_fetch_assoc($result)){
   $i++;
    $string += $row['value'].',';
   if($i % 4 == 0){
     $string = substr_replace($string, '|',strlen($string) - 1, 1); 
   }    
}

$string = substr($string, 0, strlen($string) - 1);

答案 1 :(得分:0)

通常,您始终可以将值类型转换为字符串:

$str = (string) $i["mysql_field"];

我认为你所看到的是这样的(不知道你的查询是怎样的):

$counter = 0;
$result = "";
$sql = mysql_query(...);
while ($i = mysql_fetch_array($sql)){
    $result .= $i["value"];
    if ($counter == 3){
        $counter = 0;
        $result .= "|";
    }else{
        $result .= ",";
        $counter++;
    }
}

这将添加“|”每第4次迭代的字符。