本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
JSON.ARRAPPEND
将一个或多个值附加到路径上的数组值。
语法
JSON.ARRAPPEND <key> <path> <json> [json ...]
- 
                    
key(必需)– JSON 文档类型的 Valkey 或 Redis OSS 键。
 - 
                    
path(必需)– 一个 JSON 路径。
 - 
                    
json(必需)– 要附加到数组的 JSON 值。
 
Return
如果路径是增强的语法:
- 
                    
表示每个路径处数组的新长度的整数数组。
 - 
                    
如果值不是数组,则其对应的返回值为 Null。
 - 
                    
如果路径不存在,则为
NONEXISTENT错误。 
如果路径是受限的语法:
- 
                    
整数,该数组的新长度。
 - 
                    
如果选择了多个数组值,则该命令将返回第一个更新的数组的新长度。
 - 
                    
如果路径中的值不是数组,则为
WRONGTYPE错误。 - 
                    
如果输入 json 参数之一不是有效的 JSON 字符串,则为
SYNTAXERR错误。 - 
                    
如果路径不存在,则为
NONEXISTENT错误。 
示例
增强的路径语法:
127.0.0.1:6379> JSON.SET k1 . '[[], ["a"], ["a", "b"]]' OK 127.0.0.1:6379> JSON.ARRAPPEND k1 $[*] '"c"' 1) (integer) 1 2) (integer) 2 3) (integer) 3 127.0.0.1:6379> JSON.GET k1 "[[\"c\"],[\"a\",\"c\"],[\"a\",\"b\",\"c\"]]"
受限的路径语法:
127.0.0.1:6379> JSON.SET k1 . '[[], ["a"], ["a", "b"]]' OK 127.0.0.1:6379> JSON.ARRAPPEND k1 [-1] '"c"' (integer) 3 127.0.0.1:6379> JSON.GET k1 "[[],[\"a\"],[\"a\",\"b\",\"c\"]]"