首頁 >資料庫 >mysql教程 >如何將 JSON 陣列轉換為行並在 MySQL 中使用 GROUP_CONCAT()?

如何將 JSON 陣列轉換為行並在 MySQL 中使用 GROUP_CONCAT()?

Patricia Arquette
Patricia Arquette原創
2024-11-26 06:39:10904瀏覽

How Can I Convert JSON Arrays to Rows and Use GROUP_CONCAT() in MySQL?

MySQL 中的JSON 數組到行轉換

從JSON 數組到行

要為JSON 數組中的每個元素插入一行,有一種方法是使用JSON_EXTRACT() 手動提取每個元素並將結果合併在一起。然而,一種更簡潔的方法是利用 MySQL 8 的 JSON_TABLE 函數:

這將建立一個包含一列「Value」的表,其中包含 JSON 陣列的元素。

SET @j = '[1, 2, 3]';
SELECT *
     FROM
       JSON_TABLE(
         @j,
         "$[*]"
         COLUMNS(
           Value INT PATH "$"
         )
       ) data;

JSON 陣列上的 GROUP_CONCAT()

將 JSON 陣列的元素連接成使用 GROUP_CONCAT() 的逗號分隔字串,您可以使用 JSON_TABLE 和 GROUP_CONCAT() 的CONCAT_的組合:

JSON 分割
SELECT GROUP_CONCAT(Value)
     FROM
       JSON_TABLE(
         @j,
         "$[*]"
         COLUMNS(
           Value INT PATH "$"
         )
       ) data;

對於類似STRING_SPLIT 的場景(),例如將逗號分隔的字串轉換為行,可以利用JSON_TABLE透過將字串轉換為JSON陣列:

這將建立一個包含一列「Value」的表,其中包含分隔字串的元素。

以上是如何將 JSON 陣列轉換為行並在 MySQL 中使用 GROUP_CONCAT()?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn