繁体   English   中英

将变量设置为sql查询的字段名称

[英]set variable to field name of sql query

我的目标是在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行是真正的伪部分

您想使用列名来命名变量吗?

$$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;
    }

现在,您可以通过列名称回显值。

这听起来很多余,但是您始终可以使用array_search:

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

查看更多关于array_search

这是你所追求的吗?

$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;
}

或者只是在foreach循环中使用$column$value

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM