如何在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 谢谢。
答案 0 :(得分:0)
您应该将attr
参数与路径的其余部分CONCAT()一起使其成为有效的路径表达式。
e.g。
SELECT JSON_EXTRACT(col1, CONCAT("$." , attr, ".a11"));
演示: