PBC Secondary Indexes
Request a set of keys that match a secondary index query.
Request
Protobuf
message RpbIndexReq {
enum IndexQueryType {
eq = 0;
range = 1;
}
required bytes bucket = 1;
required bytes index = 2;
required IndexQueryType qtype = 3;
optional bytes key = 4;
optional bytes range_min = 5;
optional bytes range_max = 6;
optional bool return_terms = 7;
optional bool stream = 8;
optional uint32 max_results = 9;
optional bytes continuation = 10;
optional uint32 timeout = 11;
optional bytes type = 12;
optional bytes term_regex = 13;
optional bool pagination_sort = 14;
}
Required Parameters
Parameter | Description |
---|---|
bucket |
The name of the bucket in which the Data Type is stored |
index |
The name of the index to be queried |
qtype |
The type of index query to be performed. This can take either of the two possible values of the IndexQueryType enum: eq for an exact index match for the given key or range for a range query |
Optional Parameters
Parameter | Description |
---|---|
key |
The name of the index to be queried if qtype is set to eq |
range_min and range_max |
The minimum and maximum values for a range query if qtype is set to range |
return_terms |
If set to true , the response will include matched indexed values (for range queries only) |
stream |
If set to true , keys matching the index query will be streamed to the client instead of waiting for max_results or the full result to be tabulated |
max_results |
If pagination is turned on, the number of results to be returned to the client |
continuation |
If set to true , values are returned in a paginated response |
timeout |
The timeout duration, in milliseconds, after which Riak will return an error message |
type |
The bucket type of the bucket that is being queried. If not set, the bucket type default will be used. Learn more about using bucket types. |
term_regex |
If set to a regular expression (as a binary), a term filter will be applied to the index query |
pagination_sort |
If set to true , paginated results will be sorted, first by index value, then by key |
Response
The results of a Secondary Index query are returned as a repeating list of 0 or more keys that match the given request parameters.
Protobuf
message RpbIndexResp {
repeated bytes keys = 1;
repeated RpbPair results = 2;
optional bytes continuation = 3;
optional bool done = 4;
}
Values
Parameter | Description |
---|---|
keys |
A list of keys that match the index request |
results |
If return_terms is specified with range queries, used to return matched index values as key/value pairs in RpbPair messages. More on RpbPair messages can be found in PBC Fetch Object. |
continuation |
Used for paginated responses |
done |
Used for streaming. The value will be true when the current stream is done (either max_results has been reached or there are no more results). |
Example
Request
Here we look for any exact matches of chicken
on an animal_bin
index
for a bucket named farm
.
Shell
RpbIndexReq protoc decode:
bucket: "farm"
index: "animal_bin"
qtype: 0
key: "chicken"
Hex 00 00 00 1E 19 0A 04 66 61 72 6D 12 0A 61 6E 69
6D 61 6C 5F 62 69 6E 18 00 22 07 63 68 69 63 6B 65 6E
Erlang <<0,0,0,30,25,10,10,4,102,97,114,109,18,10,97,110,105,
109,97,108,95,98,105,110,24,0,34,7,99,104,105,99,107,
101,110>>
Response
Shell
Hex 00 00 00 0F 1A 0A 03 68 65 6E 0A 07 72 6F 6F 73 74 65 72
Erlang <<0,0,0,15,26,10,3,104,101,110,10,7,114,111,111,115,116,101,114>>
RpbIndexResp protoc decode:
keys: "hen"
keys: "rooster"