繁体   English   中英

如何更改结果集中的列名并在 PHP 中使用修改后的列名创建新结果集

[英]How do i change the column names in a result set and create a new result set in PHP with modified column names

示例:我当前的结果集:

array(7) {[0]=>array(2) 

{ ["class_id"]=>string(1) "1"["class"]=>string(3)"1st"}

{ ["class_id"]=>string(1) "2"["class"]=>string(3)"2nd"}

{ ["class_id"]=>string(1) "3"["class"]=>string(3)"3rd"}

我想要一个新的结果集:

array(7) {[0]=>array(2) 

{ ["new_id"]=>string(1) "1"["new_class"]=>string(3)"1st"}

{ ["new_id"]=>string(1) "2"["new_class"]=>string(3)"2nd"}

{ ["new_id"]=>string(1) "3"["new_class"]=>string(3)"3rd"}

我不希望这影响我数据库中的列名。 只有结果集。

向我们展示您的查询。例如,如果您正在执行以下查询:

SELECT class_id, class FROM table;

将其更改为:

SELECT class_id AS new_id, class AS new_class FROM table;

在查询中更改它是最好的方法,因为您不必在 PHP 中做任何额外的工作,但是您当然也可以在 PHP 中修改它们。

// where $resultset is your original results..
foreach ($resultset as &$result) {
    $result_ = array('new_id' => $result['class_id'], 'new_class' => $result['class']);
    $result = $result_;
}

请注意,这些方法都不会影响您的数据库列。 唯一的方法是通过ALTER|MODIFY TABLE语句。

尝试这个

function rename_key(&$array, $oldkey, $newkey) {
// remember here we send value by reference using `&`
    if(array_key_exists($oldkey,$array))
    {
        $array[$newkey] = &$array[$oldkey];
        unset($array[$oldkey]);
    }
    return $array;
}

foreach($input as $k)
{
    rename_key($k, 'class_id', 'new_id');
    rename_key($k, 'class', 'new_class');
    $output[]=$k;
}
echo "<pre>";
print_r ($output);

在 foreach 循环中。 使用现有结果集中的列创建一个新数组。

暂无
暂无

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

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