如何在JSON_EXTRACT中使用mysql存储过程参数

时间:2018-03-20 17:07:15

标签: mysql mysql-5.7

如何在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 谢谢。

1 个答案:

答案 0 :(得分:0)

您应该将attr参数与路径的其余部分CONCAT()一起使其成为有效的路径表达式。

e.g。

SELECT JSON_EXTRACT(col1, CONCAT("$." , attr, ".a11"));

演示:

https://www.db-fiddle.com/f/pLrpXBpyZCEX6FySvWqiXz/0