0

我的目标是将变量设置为 mysql 查询中的字段名称。下面的一些伪代码

1.    $query = "SELECT firstName, lastName FROM users WHERE userName = 'mhopkins321';"
2.    $result = mysql_query($result);
3.    $while($row = mysql_fetch_assoc($result)){
4.         $column1 = name_of_column($row['firstName']);
5.    }
6.    echo $column1

      //Would return the string

      firstName

显然第 4 行是真正的伪部分

4

3 回答 3

1

你想用列名来命名一个变量吗?

$$row['firstName'] = $row['firstName'];

另一种方式是这样的:

    $query = "SELECT firstName, lastName FROM users WHERE userName = 'mhopkins321'";
    $result = mysql_query($result);
    $row = mysql_fetch_assoc($result);

    foreach($r as $key=>$value){
        $$key = $value;
    }

现在您可以通过列名来回显这些值。

于 2013-01-11T18:10:57.473 回答
1

这听起来是多余的,但你总是可以使用 array_search:

while($row = mysql_fetch_assoc($result)){
    $value = $row['firstName'];
    $key = array_search($value, $row);
}

在array_search上查看更多信息。

于 2013-01-11T18:27:10.257 回答
1

这就是你所追求的吗?

$query = "SELECT firstName, lastName FROM users WHERE userName = 'mhopkins321';"
$result = mysql_query($result);

$all_results = array();
$while($row = mysql_fetch_assoc($result)) {
     $formatted_row = array();
     foreach ( $row as $column => $value ) {
         $formatted_row[] = array($column, $value);
     }
     $all_results[] = $formatted_row;
}

或者只是在循环中使用$column以及$value您喜欢的方式。foreach

或者您是否特别想要第一列,可以使用 访问reset($row); $first_key = key($row);

于 2013-01-11T18:46:08.843 回答