繁体   English   中英

使用动态键和值在 php 中创建关联数组

[英]Create an associative array in php with dynamic key and value

我想在 php 中创建一个关联数组,其中包含动态键以及来自特定 mysql 表的动态值。

表名是monthly_salary其中有两列分别名为monthsalary

我得到里面的数据:

$sql = mysql_query('SELECT * FROM monthly_salary');
$sql2 = mysql_query('SELECT * FROM monthly_salary');

然后将收集到的数据分配并连接到$mon$sal

$mon = "";
$sal = "";
while($row = mysql_fetch_array($sql)){
    $mon .= $row['month'].", ";
}
while($row = mysql_fetch_array($sql2)){
    $sal .= $row['salary'].", ";
}

之后,我将它转换为数组并将其连接起来,直到它成为关联数组:

$monArray = array(substr(trim($mon), 0, -1));
$salArray = array(substr(trim($sal), 0, -1));
$key = "";
$keyWithVal = "";
foreach($monArray  as $k){
    $key .= $k." => ";
}
foreach($salArray  as $k){
    $keyWithVal .= $key.$k.",";
}

$associativeArray = array(substr(trim($keyWithVal), 0, -1));

我的问题是,当我回应它时,结果总是像这样3500=>Jan=>3500

foreach($associativeArray  as $k => $id){
    echo $k."=>".$id;
}

那么我该如何修复它并使用正确的输出Jan=>3500呢?

你把这个问题复杂化了。 这可以简单地完成,循环次数更少。

首先,您只需要运行 SQL 一次。 其次,在第一个循环中构建数组。

$sql = mysql_query('SELECT * FROM monthly_salary');

$associativeArray = array();
while($row = mysql_fetch_array($sql)){
   // Put the values into the array, no other variables needed
   $associativeArray[$row['month']] = $row['salary'];
}

foreach($associativeArray as $k => $id){
    echo $k."=>".$id;
}

你为什么不这样做:

$associativeArray = array();
while($row = mysql_fetch_array($sql)){
    $associativeArray[$row['month']] = $row['salary'];
}

以下为我创建关联数组。 array_push 不适用于关联数组,但使用一元运算符确实有效:

$associativeArray += [$key => $value];

暂无
暂无

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

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