在MySQL 中將JSON 數組轉換為行
在MySQL 5.7 中,JSON 操作得到了極大增強,為提取和處理資料提供了多種功能在JSON 結構中。然而,將 JSON 數組轉換為行的逆操作並不簡單。
JSON 數組到行
為 JSON 數組中的每個元素插入一行,以前需要使用多個 JSON_EXTRACT() 查詢的手動方法。但隨著MySQL 8 中JSON_TABLE 函數的引入,這個過程變得更加簡化:
SELECT * FROM JSON_TABLE([5, 6, 7], '$[*]' COLUMNS( Value INT PATH '$' ));
JSON 陣列到逗號分隔的字串
將a GROUP_CONCAT() 將JSON陣列轉換為逗號分隔的字串,一個技巧是使用:
set @delimited = 'a,b,c'; SELECT * FROM JSON_TABLE( CONCAT('["', REPLACE(@delimited, ',', '", "'), '"]'), '$[*]' COLUMNS( Value varchar(50) PATH '$' ) );
此方法將分隔字串視為 JSON 字串,從而產生轉換後的逗號分隔字串。
缺少STRING_SPLIT 函數
雖然MySQL 缺少專用的STRING_SPLIT() 函數,但JSON_TABLE 函數可以作為分割運算的替代,有效地將分隔字串為其分解組件。
以上是如何在 MySQL 中有效率地將 JSON 陣列轉換為行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!