summaryrefslogtreecommitdiffstats
path: root/src/commands/zinter.json
blob: 4828e21d6c520f76c085af258517ea8585496022 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
{
    "ZINTER": {
        "summary": "Returns the intersect of multiple sorted sets.",
        "complexity": "O(N*K)+O(M*log(M)) worst case with N being the smallest input sorted set, K being the number of input sorted sets and M being the number of elements in the resulting sorted set.",
        "group": "sorted_set",
        "since": "6.2.0",
        "arity": -3,
        "function": "zinterCommand",
        "get_keys_function": "zunionInterDiffGetKeys",
        "command_flags": [
            "READONLY"
        ],
        "acl_categories": [
            "SORTEDSET"
        ],
        "key_specs": [
            {
                "flags": [
                    "RO",
                    "ACCESS"
                ],
                "begin_search": {
                    "index": {
                        "pos": 1
                    }
                },
                "find_keys": {
                    "keynum": {
                        "keynumidx": 0,
                        "firstkey": 1,
                        "step": 1
                    }
                }
            }
        ],
        "reply_schema": {
            "anyOf": [
                {
                    "description": "Result of intersection, containing only the member names. Returned in case `WITHSCORES` was not used.",
                    "type": "array",
                    "items": {
                        "type": "string"
                    }
                },
                {
                    "description": "Result of intersection, containing members and their scores. Returned in case `WITHSCORES` was used. In RESP2 this is returned as a flat array",
                    "type": "array",
                    "items": {
                        "type": "array",
                        "minItems": 2,
                        "maxItems": 2,
                        "items": [
                            {
                                "description": "Member",
                                "type": "string"
                            },
                            {
                                "description": "Score",
                                "type": "number"
                            }
                        ]
                    }
                }
            ]
        },
        "arguments": [
            {
                "name": "numkeys",
                "type": "integer"
            },
            {
                "name": "key",
                "type": "key",
                "key_spec_index": 0,
                "multiple": true
            },
            {
                "token": "WEIGHTS",
                "name": "weight",
                "type": "integer",
                "optional": true,
                "multiple": true
            },
            {
                "token": "AGGREGATE",
                "name": "aggregate",
                "type": "oneof",
                "optional": true,
                "arguments": [
                    {
                        "name": "sum",
                        "type": "pure-token",
                        "token": "SUM"
                    },
                    {
                        "name": "min",
                        "type": "pure-token",
                        "token": "MIN"
                    },
                    {
                        "name": "max",
                        "type": "pure-token",
                        "token": "MAX"
                    }
                ]
            },
            {
                "name": "withscores",
                "token": "WITHSCORES",
                "type": "pure-token",
                "optional": true
            }
        ]
    }
}