web-dev-qa-db-ja.com

動的なキーと値を持つ連想配列をPHPで作成する

動的キーと特定のmysqlテーブルからの動的値を使用して、phpで連想配列を作成したいと思います。

テーブル名はmonthly_salaryで、それぞれmonthおよびsalaryという2つの列があります。

その中のデータを取得します。

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

私の問題は、エコーしたときの結果が常に次のようになることです500 => Jan => 35

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

それで、どうすれば修正でき、正しい出力Jan => 35が得られますか?

8
scireon

あなたはこの問題を非常に複雑にしています。これは、より少ないループで簡単に実行できます。

まず、SQLを1回実行するだけで済みます。次に、最初のループで配列を作成します。

$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;
}
28
Rocket Hazmat

なぜあなたはやらないのですか:

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