MySQL JSON_EXTRACT路径表达式错误

2ac*_*ary 12 mysql json

语法看起来对我来说,任何帮助将不胜感激!

mysql> select fieldnames from tablename limit 5;
+--------------------------------------------------------+
| fieldnames                                             |
+--------------------------------------------------------+
| {"example-field-1": "val2"}                            |
| {"example-field-2": "val1"}                            |
| {"example-field-1": "val1", "example-field-3": "val1"} |
| {"example-field-2": "val1"}                            |
| {"example-field-2": "val2"}                            |
+--------------------------------------------------------+
mysql> select JSON_EXTRACT(fieldnames, '$.example-field-1') from tablename;
ERROR 3143 (42000): Invalid JSON path expression. The error is around character position 17 in '$.example-field-1'.
Run Code Online (Sandbox Code Playgroud)

MySQL 5.7.10

ale*_*dov 25

你能从https://dev.mysql.com/doc/refman/5.7/en/json.html上试试这个建议吗

如前所述,如果路径表达式中的未加引号的键名称不合法,则必须引用命名键的路径组件.让$引用这个值.

select JSON_EXTRACT(fieldnames, '$."example-field-1"') from tablename;
Run Code Online (Sandbox Code Playgroud)

  • 我真的希望Mysql文档会突出更多.这个答案确实让我无法走下兔子洞. (3认同)
  • 谢谢!就是这样.引号内的报价. (2认同)