第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

將兩個(gè)表的結(jié)果合并到JSON中

將兩個(gè)表的結(jié)果合并到JSON中

PHP
冉冉說 2021-03-31 13:26:21
我之前曾問過類似的問題,但沒有book_no在該問題中包括該列,并且由于我想要的解決方案必須包括此列才能為我提供正確的JSON結(jié)構(gòu),因此我得到的解決方案因此無法正常工作。因此,我將使用適當(dāng)?shù)男畔⒅匦掳l(fā)布此信息。我有兩個(gè)表,words和paragraph。下words表如下:+----+---------+--------------+---------+---------+| id | book_no | paragraph_no | word_no |   word  |+----+---------+--------------+---------+---------+|  1 |    1    |       1      |    1    |  hello  |+----+---------+--------------+---------+---------+|  2 |    1    |       1      |    2    |  how    |+----+---------+--------------+---------+---------+|  3 |    1    |       1      |    3    |  are    |+----+---------+--------------+---------+---------+|  4 |    1    |       1      |    4    |  you    |+----+---------+--------------+---------+---------+下paragraph表如下:+----+---------+--------------+-------------------+| id | book_no | paragraph_no |     paragraph     |+----+---------+--------------+-------------------+|  1 |    1    |       1      | hello how are you |+----+---------+--------------+-------------------+我希望words表WHERE中的所有列book_no都是1,而段落表中具有相同WHERE子句的段落列都在一個(gè)JSON結(jié)果中。像這樣的東西:{    "1": [ <-- this is paragraph_no        "words": [            {                "id": "1",                "word_no": "1",                "paragraph_no": "1",                "word": "hello"            },            {                "id": "2",                "word_no": "2",                "paragraph_no": "1",                "word": "how"            },            // and so on...        ],        "paragraph": [            {                "paragraph": "hello how are you"            }        ]    ]}僅輸出這樣的單詞:{    "1": [ <-- this is paragraph_no        {            "id": "1",            "word_no": "1",            "paragraph_no": "1",            "word": "hello"        },        {            "id": "2",            "word_no": "2",            "paragraph_no": "1",            "word": "how"        },        // and so on...    ]}如何獲得所需的JSON輸出?
查看完整描述

1 回答

?
拉丁的傳說

TA貢獻(xiàn)1789條經(jīng)驗(yàn) 獲得超8個(gè)贊

這段代碼會(huì)產(chǎn)生您需要的輸出嗎?


$result_w = $conn->query("SELECT * FROM words;");

$results_w = $result_w->fetch_all(MYSQLI_ASSOC);


$words_per_paragraph = [];

foreach($results_w as $key => $row) {

    $words_per_paragraph[$row['paragraph_no']][] = $row;

}


$result_p = $conn->query("SELECT * FROM paragraph;");

$results_p = $result_p->fetch_all(MYSQLI_ASSOC);


$data = [];

foreach($results_p as $key => $row) {

    $p_no = $row['paragraph_no'];

    $words = [];

    if(array_key_exists($p_no, $words_per_paragraph)) {

        $words = $words_per_paragraph[$p_no];

    }

    $data[$p_no] = [

        'words' => $words,

        'paragraph' => $row

    ];

}

的內(nèi)容$data(出于測試目的,我沒有在第2段中添加任何文字):


{

   "1":{

      "words":{

         "id":"4",

         "book_no":"1",

         "paragraph_no":"1",

         "word_no":"4",

         "word":"you"

      },

      "paragraph":{

         "id":"1",

         "book_no":"1",

         "paragraph_no":"1",

         "paragraph":"hello how are you"

      }

   },

   "2":{

      "words":[


      ],

      "paragraph":{

         "id":"3",

         "book_no":"1",

         "paragraph_no":"2",

         "paragraph":"I'm fine and you?"

      }

   }

}

也許您可以更改數(shù)據(jù)庫表結(jié)構(gòu)以在一條語句中獲得所有內(nèi)容。


查看完整回答
1 反對 回復(fù) 2021-04-23
  • 1 回答
  • 0 關(guān)注
  • 276 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號