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中文網其他相關文章!