MYSQL触发器:JSON_SEARCH整数的json数组中的整数值

时间:2016-11-01 08:48:08

标签: mysql json triggers

这是我第一次在这里提问,如果我犯了任何业余错误,请原谅我。

我希望使用json_search来获取与值对应的数组路径。

我试过了,这个有用:

SET @j = '["3", "2", "1"]';
SELECT json_search(@j, 'one', '2');

返回$ [1];

我已经尝试过,但这不起作用:(如何使其工作?)

SET @j = '[3, 2, 1]';
SELECT json_search(@j, 'one', 2);

返回null;

基本上我想将@j存储为整数数组而不是字符串数组,以便进行索引。有没有办法我可以将整数数组更改为字符串数组进行比较,如果json_search无法使用整数?

提前致谢!

4 个答案:

答案 0 :(得分:4)

这是设计,虽然我不同意mySQL团队。这应该实施。

https://bugs.mysql.com/bug.php?id=79233 [关闭]

  

https://dev.mysql.com/worklog/task/?id=7909的规范说:   "此函数将路径返回给定字符串。归来了   path(s)标识作为字符的对象成员或数组槽   字符串"

     

所以看来这个功能的目的是寻找   字符串。应该更新文档以澄清该文档   函数用于搜索字符串标量,而不是用于搜索标量   一般

答案 1 :(得分:0)

我尝试了一种解决方法,即CONCAT字符串并将其强制转换为JSON并更新表。这不是最优雅的方式,所以如果你们有任何建议,请告诉我! :)

BEGIN
DECLARE var1 INT default -2; //offsets
DECLARE var2 INT default 2; //offsets
SELECT StatusID into @statusList FROM UserStatusesIndex;
SET @statusID_to_remove = OLD.StatusID;
SET @startIndex = INSTR(@statusList, @statusID_to_remove);
SET @charLength = CHAR_LENGTH(@statusID_to_remove);

IF @startIndex <= 2 THEN SET var1=-1, var2=2; //If its the first index
ELSEIF (CHAR_LENGTH(@statusList) - @startIndex <= 2) THEN SET var1=-3, var2=0;  //If its the last index
ELSE SET var1=-2, var2=2;
END IF;

SET @newJson=CAST(CONCAT(SUBSTRING(@statusList, 1, @startIndex+var1), SUBSTR(@statusList, @startIndex + @charLength+var2, CHAR_LENGTH(@statusList) - @startIndex - @charLength+2)) as JSON);
UPDATE UserStatusesIndex SET StatusID=@newJson WHERE StatusCreator=OLD.StatusCreator;
END

谢谢!

答案 2 :(得分:0)

你可以用这样的字母字符作为你的 JSON_ARRAY 的 INTEGER 前缀:

SET @trailers := JSON_ARRAY(
't9'
,'t10'
,'t11'
,'t12'
,'t13'
,'t14'
);

然后,当您使用它通过 JSON_SEARCH 定位关联的 id 时,您可以使用 CONCAT 在您的表中使用相同的值作为前缀,如下所示:

select * from trailers.trailer t
where 
JSON_SEARCH(@open_trailers, 'one', concat('t', t.trailer_id )) IS NOT NULL
;

这应该可行,但要注意可能出现的潜在性能问题。

祝你好运!

答案 3 :(得分:-2)

这似乎有效:

SET @j = '[3, 2, 1]';
SELECT JSON_CONTAINS(@j, '3', '$');