MySQL JSON:按键值查找对象
在 MySQL 中使用 JSON 对象时,您可能会遇到需要搜索的情况使用来自另一个对象的键的 JSON 数据中的特定对象。如果没有适当的功能,这可能是一项具有挑战性的任务。在本文中,我们将讨论使用 JSON_TABLE() 来实现此目的的有效方法。
JSON_TABLE() 的语法如下:
<code class="sql">JSON_TABLE(expression, path_expression COLUMNS *(expression_list))</code>
在这种情况下,我们有一个JSON 结构类似于原始问题中提供的结构,其中我们有一组包含键值对的对象。我们希望在搜索另一个键时从一个键检索具有指定值的对象。
使用 JSON_TABLE(),我们可以编写如下查询:
<code class="sql">SELECT field_options.* FROM fields CROSS JOIN JSON_TABLE(options, '$[*]' COLUMNS( text TEXT PATH '$.text', value TEXT PATH '$.value' ) ) field_options WHERE field_options.value = 1;</code>
以下是它的方法有效:
结果将是包含 JSON 数组中的匹配对象的表。
但是,值得考虑使用 JSON 是否是此类数据的最佳解决方案。如果您的数据可以在规范化的关系表结构中更有效地表示,那么最好避免使用 JSON。这可以简化查询和维护任务。
以上是如何使用 MySQL JSON_TABLE() 按键值查找特定 JSON 对象?的详细内容。更多信息请关注PHP中文网其他相关文章!