首頁 >資料庫 >mysql教程 >如何在 MySQL 中有效率地將 JSON 陣列轉換為行?

如何在 MySQL 中有效率地將 JSON 陣列轉換為行?

Patricia Arquette
Patricia Arquette原創
2024-11-30 14:33:15332瀏覽

How Can I Efficiently Convert JSON Arrays into Rows in MySQL?

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

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