首頁  >  文章  >  資料庫  >  如何在 MySQL 中查詢 JSON 陣列:可以使用 JSON_TABLE() 從 JSON 陣列中擷取特定值嗎?

如何在 MySQL 中查詢 JSON 陣列:可以使用 JSON_TABLE() 從 JSON 陣列中擷取特定值嗎?

Susan Sarandon
Susan Sarandon原創
2024-10-30 00:16:03181瀏覽

How to Query JSON Arrays in MySQL: Can JSON_TABLE() be used to retrieve specific values from a JSON array?

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

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