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

Posted

技术标签:

【中文标题】MYSQL 触发器:JSON_SEARCH 整数 json 数组中的整数值【英文标题】:MYSQL Triggers: JSON_SEARCH an integer value in a json array of integers 【发布时间】:2017-03-14 09:23:55 【问题描述】:

我希望使用 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);

返回空值;

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

【问题讨论】:

看来这个bug还没有修复:bugs.mysql.com/bug.php?id=79316 哦,这是一个错误 :(,看来我必须将数据类型改回 varchar 呵呵 【参考方案1】:

我尝试了一种解决方法,即 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】:

这似乎有效:

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

【讨论】:

总是返回包含或不包含,而不是路径,与所提出的问题无关【参考方案3】:

这是设计使然,虽然我不能同意 mySQL 团队的观点。这应该被实施。

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

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

所以看来这个函数的目的是搜索 字符串。应更新文档以阐明 函数用于搜索字符串标量,而不是搜索中的标量 一般。

【讨论】:

这真的很令人困惑,因为json_array(1,2,3) 返回的是[1, 2, 3] 而不是["1", "2", "3"],所以人们自然会认为 json_search 也适用于整数数组。【参考方案4】:

您可以在 INTEGER 的 JSON_ARRAY 前面加上一个字母字符,如下所示:

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
;

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

祝你好运!

【讨论】:

以上是关于MYSQL 触发器:JSON_SEARCH 整数 json 数组中的整数值的主要内容,如果未能解决你的问题,请参考以下文章

mysql中json_contains和json_search的区别

使用 mysql JSON_SEARCH:为啥我必须引用数字?

使用 MySQL Json_search 函数使用不区分大小写的搜索获取 JSON 数据中值的路径表达式

结合 JSON_SEARCH 和 JSON_EXTRACT 得到我:“无效的 JSON 路径表达式。”

MySQL - 搜索 JSON 数据列

Mysql中的JSON函数使用教程