首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MYSQL触发器:在整数的json数组中JSON_SEARCH一个整数值

MYSQL触发器:在整数的json数组中JSON_SEARCH一个整数值
EN

Stack Overflow用户
提问于 2016-11-01 16:48:08
回答 4查看 4K关注 0票数 16

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

我已经尝试过了,这是可行的:

代码语言:javascript
运行
复制
SET @j = '["3", "2", "1"]';
SELECT json_search(@j, 'one', '2');

返回$1;

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

代码语言:javascript
运行
复制
SET @j = '[3, 2, 1]';
SELECT json_search(@j, 'one', 2);

返回null;

基本上,我希望将@j存储为整数数组,而不是字符串数组,用于索引目的。如果json_search无法处理整数,有没有办法将整数数组转换为字符串数组进行比较?

EN

回答 4

Stack Overflow用户

发布于 2017-10-13 05:20:33

这是设计出来的,尽管我不同意mySQL团队的观点。这应该得到实现。

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

https://dev.mysql.com/worklog/task/?id=7909的规范说:“这个函数返回给定字符串的路径。返回的路径标识对象成员或字符串的数组位置。”

因此,这个函数的目的似乎是搜索字符串。应该更新文档以澄清该函数用于搜索字符串标量,而不是一般的标量。

票数 8
EN

Stack Overflow用户

发布于 2016-11-02 12:51:58

我尝试了一种变通方法,即连接字符串并将其转换回JSON,然后更新表。这不是最优雅的方式,所以如果你们有任何建议,请告诉我!:)

代码语言:javascript
运行
复制
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

谢谢!

票数 0
EN

Stack Overflow用户

发布于 2021-04-22 08:50:04

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

代码语言:javascript
运行
复制
SET @trailers := JSON_ARRAY(
't9'
,'t10'
,'t11'
,'t12'
,'t13'
,'t14'
);

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

代码语言:javascript
运行
复制
select * from trailers.trailer t
where 
JSON_SEARCH(@open_trailers, 'one', concat('t', t.trailer_id )) IS NOT NULL
;

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

祝你好运!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40356672

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档