Jin*_*000 11 mysql json triggers
这是我第一次在这里问一个问题,如果我犯了任何业余错误,请原谅我.
我希望使用json_search来获取与值对应的数组路径.
我试过,这有效:
SET @j = '["3", "2", "1"]';
SELECT json_search(@j, 'one', '2');
Run Code Online (Sandbox Code Playgroud)
返回$ [1];
我试过了,这不起作用:(我如何使这项工作?)
SET @j = '[3, 2, 1]';
SELECT json_search(@j, 'one', 2);
Run Code Online (Sandbox Code Playgroud)
返回null;
基本上我想将@j存储为整数数组而不是字符串数组以用于索引目的.有没有办法我可以将整数数组更改为字符串数组进行比较,如果json_search无法使用整数?
提前致谢!
这是设计使然,尽管我不同意mySQL团队。这应该实现。
https://bugs.mysql.com/bug.php?id=79233 [关闭]
https://dev.mysql.com/worklog/task/?id=7909上的规范说:“此函数返回给定字符串的路径。返回的路径标识对象成员或数组插槽,它们是字符串。”
因此,该功能的意图似乎是搜索字符串。应该更新文档以阐明该函数是用于搜索字符串标量,而不是通常的标量。
我尝试了一种解决方法,即 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
Run Code Online (Sandbox Code Playgroud)
谢谢!