質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.50%

  • PHP

    24437questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • JSON

    1484questions

    JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

  • 配列

    627questions

    配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

PHP・データベース連携で連想配列に連想配列を追加する方法

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,254

arito91

score 3

連想配列に対してjson_encode関数を使用し、以下のようなjson形式の内容を出力したいと考えています。
データベースと連携して、見つかったデータの数だけ$arrayの連想配列"III"の中に連想配列を追加していきたいです。

{
    "AAA":"$BBB",
    "BBB":"$GGG",
    "CCC":"$HHH",
    "DDD":"$EEE",
    "III":
    [{
        "JJJ":KKK,
        "LLL":"MMM,
        "NNN":"OOO",
        "PPP":"QQQ",
        "RRR":"SSS",
        "TTT":"UUU",
        "VVV":"WWW"
    },
    {
        "JJJ":XXX,
        "LLL":"YYY,
        "NNN":"ZZZ",
        "PPP":"@@@",
        "RRR":"***",
        "TTT":"???",
        "VVV":"!!!"
    }],
    {
        "JJJ":くくく,
        "LLL":"けけけ,
        "NNN":"こここ",
        "PPP":"さささ",
        "RRR":"ししし",
        "TTT":"すすす",
        "VVV":"せせせ"
    }]
}

ただ、連想配列の中に連想配列をある分だけどんどん追加する場合どのように書けばいいのか調べてもピンとこない状態です。
どなたかご教授いただけないでしょうか。

私が試したのは以下のような内容です。
(参考にしたURLはhttps://teratail.com/questions/32086です。)

//■元の連想配列

$array = array(
    "AAA"    =>    "$FFF",
    "BBB"    =>    "$GGG",
    "CCC"    =>    "$HHH",
    "DDD"    =>    "$EEE",
    "III"    =>     array()
    );

//■ループごとに追加されていく内容
$p_array = array
    ("III" => array(
        "JJJ"    =>    $KKK,
        "LLL"    =>    "$MMM",
        "NNN"    =>    "$OOO",
        "PPP"    =>    "$QQQ",
        "RRR"    =>    "$SSS",
        "TTT"    =>    "$UUU",
        "VVV"    =>    "$WWW"
    )
);

//■追加
$array = array_merge($array["III"],$p_array["III"]);
//結果はnull……。
//(どころか、1度目のループの時点で"AAA"~"DDD"が完全に消えてしまいました……。)
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+2

ご提示のJSONを実現するのであればこんな感じ。

$array = array(
    "AAA"    =>    "$FFF",
    "BBB"    =>    "$GGG",
    "CCC"    =>    "$HHH",
    "DDD"    =>    "$EEE",
    "III"    =>     array()
    );

//省略:DBから取得の処理

//取得結果をループ
while(~~~~){
 //省略:$KKKとか$MMMとかで受け取る処理

  $row = array(
        "JJJ"    =>    $KKK,
        "LLL"    =>    $MMM,
        "NNN"    =>    $OOO,
        "PPP"    =>    $QQQ,
        "RRR"    =>    $SSS,
        "TTT"    =>    $UUU,
        "VVV"    =>    $WWW
    );
   $array["III"][] = $row;
}


どのようなタイミングや仕様で今回のJSONおよび配列を作るかにも夜のですが、
もし、DBから取得したカラム名をそのまま配列のキーとして使うようであればfetchで連想配列としてDB情報を取得して$rowの配列を作らずそのまま突っ込む方が行数が少なく済むので良いですね。

//取得結果をループ Mysqlの場合
while($rowdata = mysqli_fetch_assoc($res)){
   $array["III"][] = $rowdata;
}

 プチ解説

配列の[]に入れていくことで配列の0番目から順番に値を入れていくことができます。
その結果をJSONにすることで下記のような結果となります。
[
//内容
],
[
//内容
],
・・・
var_dumpすると
[0]=>array(内容の個数){内容},
[1]=>array(内容の個数){内容},
・・・
みたいな感じですね。

そういえば、JSON提示されていますがちょこちょこ"の閉じがなかったりしますので調整・記法を統一しておいてください。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/06/14 00:04

    ありがとうございます。
    []の解釈もご教授いただけて大変助かりました。

    また、jsonに関してのご指摘ありがとうございます。
    不慣れなので、この点気を付けていきます。

    キャンセル

+2

仕様が明確でないので微妙ですが、配列の追加は以下のように行います。

<?php
$array = array(
    "AAA"    =>    "FFF",
    "BBB"    =>    "GGG",
    "CCC"    =>    "HHH",
    "DDD"    =>    "EEE",
    "III"    =>     array()
    );

$p_array = array
    ("III" => array(
        "JJJ"    =>    "KKK",
        "LLL"    =>    "MMM",
        "NNN"    =>    "OOO",
        "PPP"    =>    "QQQ",
        "RRR"    =>    "SSS",
        "TTT"    =>    "UUU",
        "VVV"    =>    "WWW"
    )
);

$q_array = array
    ("III" => array(
        "JJJ"    =>    "KKK",
        "LLL"    =>    "MMM",
        "NNN"    =>    "OOO",
        "PPP"    =>    "QQQ",
        "RRR"    =>    "SSS",
        "TTT"    =>    "UUU",
        "VVV"    =>    "WWW"
    )
);

$array['III'][] = $p_array['III'];
$array['III'][] = $q_array['III'];


DB のデータとの組み合わせは、都度突っ込むか、foreach で実装すればイケると思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/06/14 00:05

    ありがとうございます。大変助かりました。
    記法は結構シンプルなのですね。
    勉強になります。

    キャンセル

同じタグがついた質問を見る

  • PHP

    24437questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • JSON

    1484questions

    JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

  • 配列

    627questions

    配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。