在MySQL 中查詢JSON 數組:使用JSON_TABLE() 的解決方案
您可以使用JSON_SEARCH 等SQLSQL 函數從JSONH特定值,但這僅提供到所需節點的路徑。若要將路徑搜尋與實際值檢索結合起來,您可以使用 JSON_TABLE() 函數。
JSON_TABLE() 將 JSON 文件轉換為虛擬表,讓您可以對其元素套用 WHERE 和 SELECT 等 SQL 操作。透過指定數組中的列及其路徑,您可以輕鬆過濾和投影所需的屬性。考慮以下範例:
SELECT j.strength FROM mytable, JSON_TABLE(mycol, '$[*]' COLUMNS ( race VARCHAR(10) PATH '$.Race', strength INT PATH '$.strength' ) ) AS j WHERE j.race = 'Knight'
此查詢將傳回騎士種族的強度值。但是,它要求您明確定義屬性名稱及其路徑,當資料結構是動態或未定義時,這可能不可行。
值得注意的是,使用 JSON_TABLE() 涉及將 JSON 文件轉換為每個查詢都使用虛擬表,如果資料很大,這可能會影響效能。此外,這種方法要求您指定要搜尋的屬性字段,這限制了它在完全未定義的資料結構中的使用。
以上是如何在 MySQL 中查詢 JSON 陣列:可以使用 JSON_TABLE() 從 JSON 陣列中擷取特定值嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!