[英]INSERT INTO sql query is using variable string rather than field name
[英]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.