如何在 JSON_EXTRACT 中使用 mysql 存储过程参数。
表:
SELECT * FROM table1;
col1: {"a1":{"a11":"101","a12":"102"},"a2":{"a22":"201","a23":"202"}}
存储过程代码:
DROP PROCEDURE IF EXISTS my_procedure;
DELIMITER //
CREATE PROCEDURE `my_procedure` (IN attr varchar(50))
BEGIN
SELECT JSON_EXTRACT(col1, '$.',attr,'.a11') FROM table1;
END//
DELIMITER ;
调用存储过程:
call my_procedure('a1');
错误:
ERROR 3143 (42000): Invalid JSON path expression. The error is around character position 2.
如果我将存储过程代码更改为:
SELECT JSON_EXTRACT(col1, '$.a1.a11') FROM table1; /* this will work*/
但想在存储过程参数中传递JSON_EXTRACT路径。我使用的是mysql 5.7.21 谢谢。
最佳答案
您应该将您的 attr
参数与路径的其余部分进行 CONCAT() 以使其成为有效的路径表达式。
例如
SELECT JSON_EXTRACT(col1, CONCAT("$." , attr, ".a11"));
演示:
关于mysql - 如何在JSON_EXTRACT中使用mysql存储过程参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49390245/