RedisX v0.9
A simple, light-weight Redis database client
Loading...
Searching...
No Matches
redisx-tab.c File Reference

Macros

#define SCAN_INITIAL_STORE_CAPACITY   256
 Number of Redis keys to allocate initially when using SCAN to get list of keywords.
 

Functions

void redisxDestroyEntries (RedisEntry *entries, int count)
 
void redisxDestroyKeys (char **keys, int count)
 
char ** redisxGetKeys (Redis *redis, const char *table, int *n)
 
int redisxGetScanCount (Redis *redis)
 
char * redisxGetStringValue (Redis *redis, const char *table, const char *key, int *len)
 
RedisEntryredisxGetTable (Redis *redis, const char *table, int *n)
 
RESPredisxGetValue (Redis *redis, const char *table, const char *key, int *status)
 
int redisxMultiSet (Redis *redis, const char *table, const RedisEntry *entries, int n, boolean confirm)
 
int redisxMultiSetAsync (RedisClient *cl, const char *table, const RedisEntry *entries, int n, boolean confirm)
 
char ** redisxScanKeys (Redis *redis, const char *pattern, int *n, int *status)
 
RedisEntryredisxScanTable (Redis *redis, const char *table, const char *pattern, int *n, int *status)
 
int redisxSetScanCount (Redis *redis, int count)
 
int redisxSetValue (Redis *redis, const char *table, const char *key, const char *value, boolean confirm)
 
int redisxSetValueAsync (RedisClient *cl, const char *table, const char *key, const char *value, boolean confirm)
 

Detailed Description

Date
Created on Aug 26, 2024
Author
Attila Kovacs

Table access functions for the RedisX library. These functions can be used both for Redis hash tables and for global key/value data in a Redis database.

Function Documentation

◆ redisxDestroyEntries()

void redisxDestroyEntries ( RedisEntry entries,
int  count 
)

Destroy a RedisEntry array with dynamically allocate keys/values, such as returned e.g. by redisxScanTable().

IMPORTANT:

You should not use this function to destroy RedisEntry[] arrays, which contain static string references (keys or values). If the table contains only static references you can simply call free() on the table. Otherwise, you will have to first free only the dynamically sized string fields within before calling free() on the table itself.

Parameters
entriesPointer to the entries array (or single entry data). It may be NULL, in which case this call will return immediately.
countThe number of elements contained in the array
See also
redisxScanTable()
redisxGetTable()

References RedisEntry::key, and RedisEntry::value.

◆ redisxDestroyKeys()

void redisxDestroyKeys ( char **  keys,
int  count 
)

Destroy an array of keywords (i.e. an array of string pointers), such as returned e.g. by redisxScanKeys().

Parameters
keysAn array of string pointers
countThe number of strings contained in the array. It may be NULL., in which case this call will return immediately.
See also
redisxScanKeys()
redisxGetKeys()

◆ redisxGetKeys()

char ** redisxGetKeys ( Redis redis,
const char *  table,
int *  n 
)

Returns all the key names stored in a given hash table

Parameters
[in]redisPointer to a Redis instance.
[in]tableThe hashtable from which to retrieve a value or NULL if to use the global table.
[out]nPointer to the integer in which the number of elements or an error (<0) is returned. It may return an error value from redisxRequest(), or:

REDIS_NULL If got a null or empty response from Redis UNEXPECTED_RESP If the response from Redis was not the expected array type

Returns
An array with pointers to key names from this table or NULL if there was an error (see parameter n for an error status from redisx.h / xchange.h).
See also
redisxScanKeys()
redisxDestroyKeys()

References RESP::n, redisxCheckDestroyRESP(), redisxDestroyRESP(), redisxRequest(), RESP_ARRAY, RESP::value, x_error(), X_NULL, and x_trace_null().

◆ redisxGetScanCount()

int redisxGetScanCount ( Redis redis)

Returns the COUNT parameter currently set to be used with Redis SCAN-type commands

Parameters
redisPointer to a Redis instance.
Returns
The current COUNT to use for SCAN-type commands, or <0 in case of an error.
See also
redisxGetScanCount()
redisxScanKeys()
redisxScanTable()

◆ redisxGetStringValue()

char * redisxGetStringValue ( Redis redis,
const char *  table,
const char *  key,
int *  len 
)

Retrieve a variable from Redis as a string (or byte array), through the interactive connection. This is not the highest throughput mode (that would be sending asynchronous pipeline request, and then asynchronously collecting the results such as with redisxSendRequestAsync() / redisxReadReplyAsync()), because it requires separate network roundtrips for each and every request. But, it is simple and perfectly good method when one needs to retrieve only a few (<1000) variables per second...

The call effectively implements a Redis GET (if the table argument is NULL) or HGET call.

Parameters
[in]redisPointer to a Redis instance.
[in]tableHashtable from which to retrieve a value or NULL if to use the global table.
[in]keyField name (i.e. variable name).
[out]len(optional) pointer in which to return the length (>=0) of the value or else an error code (<0) defined in xchange.h / redisx.h
Returns
A freshly allocated RESP array containing the Redis response, or NULL if no valid response could be obtained.
See also
redisxGetValue()

References RESP::n, redisxCheckRESP(), redisxDestroyRESP(), redisxGetValue(), RESP_BULK_STRING, RESP::value, X_SUCCESS, and x_trace_null().

◆ redisxGetTable()

RedisEntry * redisxGetTable ( Redis redis,
const char *  table,
int *  n 
)

Returns all the key/value pairs stored in a given hash table

Parameters
[in]redisPointer to a Redis instance.
[in]tableHashtable from which to retrieve a value or NULL if to use the global table.
[out]nPointer to the integer in which the number of elements or an error (<0) is returned. It may return an error value from redisxRequest(), or:

REDIS_NULL If got a null or empty response from Redis UNEXPECTED_RESP If the response from Redis was not the expected array type

Returns
A table of all entries (key/value pairs) from this table or NULL if there was an error (see parameter n).
See also
redisxScanTable()
redisxDEstroyEntries()

References RedisMap::key, RedisEntry::key, RESP::n, redisxCheckDestroyRESP(), redisxDestroyRESP(), redisxRequest(), RESP3_MAP, RESP_ARRAY, RESP::type, RESP::value, RedisMap::value, RedisEntry::value, x_error(), X_GROUP_INVALID, and x_trace_null().

◆ redisxGetValue()

RESP * redisxGetValue ( Redis redis,
const char *  table,
const char *  key,
int *  status 
)

Retrieve a variable from Redis (as an undigested RESP), through the interactive connection. This is not the highest throughput mode (that would be sending asynchronous pipeline request, and then asynchronously collecting the results such as with redisxSendRequestAsync() / redisxReadReplyAsync()), because it requires separate network roundtrips for each and every request. But, it is simple and perfectly good method when one needs to retrieve only a few (<1000) variables per second...

The call effectively implements a Redis GET (if the table argument is NULL) or HGET call.

Parameters
[in]redisPointer to a Redis instance.
[in]tableHashtable from which to retrieve a value or NULL if to use the global table.
[in]keyField name (i.e. variable name).
[out]status(optional) pointer to the return error status, which is either X_SUCCESS on success or else the error code set by redisxArrayRequest(). It may be NULL if not required.
Returns
A freshly allocated RESP containing the Redis response, or NULL if no valid response could be obtained. Values are returned as RESP_BULK_STRING (count = 1), or else type RESP_ERROR or RESP_NULL if Redis responded with an error or null, respectively.
See also
redisxGetStringValue()

References redisxRequest(), x_error(), X_GROUP_INVALID, X_NAME_INVALID, X_SUCCESS, and x_trace_null().

◆ redisxMultiSet()

int redisxMultiSet ( Redis redis,
const char *  table,
const RedisEntry entries,
int  n,
boolean  confirm 
)

Sets multiple key/value pairs in a given hash table.

Parameters
redisPointer to a Redis instance.
tableHashtable from which to retrieve a value.
entriesPointer to an array of key/value pairs.
nNumber of entries.
confirmWhether we should get a confirmation from the server (requires a round-trip).
Returns
X_SUCCESS (0) on success or an error code (<0) from redisx.h / xchange.h.

References Redis::interactive, REDIS_ERROR, redisxCheckRESP(), redisxCheckValid(), redisxDestroyRESP(), redisxLockConnected(), redisxMultiSetAsync(), redisxReadReplyAsync(), redisxUnlockClient(), RESP_SIMPLE_STRING, RESP::value, x_error(), X_GROUP_INVALID, X_NULL, X_SIZE_INVALID, and X_SUCCESS.

◆ redisxMultiSetAsync()

int redisxMultiSetAsync ( RedisClient cl,
const char *  table,
const RedisEntry entries,
int  n,
boolean  confirm 
)

Sets multiple key/value pairs in a given hash table. This function should be called with exclusive access to the client.

Parameters
clA Redis client to which we have exclusive access.
tableHashtable from which to retrieve a value.
entriesPointer to an array of key/value pairs.
nNumber of entries.
confirmWhether we should get a confirmation from the server (requires a round-trip).
Returns
X_SUCCESS (0) on success or an error code (<0) from redisx.h / xchange.h.
See also
redisxMultiSet()
redisxLockClient()

References RedisEntry::length, redisxSendArrayRequestAsync(), redisxSkipReplyAsync(), x_error(), X_FAILURE, X_GROUP_INVALID, X_NULL, X_SIZE_INVALID, X_SUCCESS, and x_trace().

◆ redisxScanKeys()

char ** redisxScanKeys ( Redis redis,
const char *  pattern,
int *  n,
int *  status 
)

Returns an alphabetical list of the Redis keys using the Redis SCAN command. Because it uses the scan command, it is guaranteed to not hog the database for excessive periods, and hence it is preferable to redisxGetKeys(table=NULL).

Some data may be returned even if there was an error, and the caller is responsible for cleaning up the returned srotage elements.

The caller may adjust the amount of work performed in each scan call via the redisxSetScanCount() function, prior to calling this.

Parameters
[in]redisPointer to a Redis instance.
[in]patternkeyword pattern to match, or NULL for all keys.
[out]nPointer to the integer in which the number of elements
[out]statusinteger in which to return the status, which is X_SUCCESS (0) if successful, or may an error value from redisxRequest(), or:

X_NULL If one of the arguments is NULL REDIS_NULL If got a null or empty response from Redis UNEXPECTED_RESP If the response from Redis was not the expected array type

Returns
An array with pointers to key names from this table or NULL.
See also
redisxGetKeys()
redisxSetScanCount()
redisxDestroyKeys()

References RESP::n, redisxArrayRequest(), redisxCheckRESP(), redisxDestroyRESP(), redisxGetScanCount(), RESP_ARRAY, RESP_BULK_STRING, SCAN_INITIAL_STORE_CAPACITY, RESP::value, x_error(), X_NULL, X_SUCCESS, x_trace(), xStringCopyOf(), and xvprintf.

◆ redisxScanTable()

RedisEntry * redisxScanTable ( Redis redis,
const char *  table,
const char *  pattern,
int *  n,
int *  status 
)

Returns an alphabetical list of the Redis hash table data using the Redis HSCAN command. Because it uses the scan command, it is guaranteed to not hog the database for excessive periods, and hence it is preferable to redisxGetTable().

Some data may be returned even if there was an error, and the caller is responsible for cleaning up the returned srotage elements.

The caller may adjust the amount of work performed in each scan call via the redisxSetScanCount() function, prior to calling this.

Parameters
[in]redisPointer to a Redis instance.
[in]tableName of Redis hash table to scan data from
[in]patternkeyword pattern to match, or NULL for all keys.
[out]nPointer to the integer in which the number of elements
[out]statusinteger in which to return the status, which is X_SUCCESS (0) if successful, or may an error value from redisxRequest(), or:

X_NULL If one of the arguments is NULL REDIS_NULL If got a null or empty response from Redis UNEXPECTED_RESP If the response from Redis was not the expected array type

Returns
A RedisEntry[] array or NULL.
See also
redisxGetKeys()
redisxSetScanCount()
redisxDestroyEntries()

References RedisEntry::key, RedisEntry::length, RESP::n, redisxArrayRequest(), redisxCheckRESP(), redisxDestroyRESP(), redisxGetScanCount(), RESP_ARRAY, RESP_BULK_STRING, SCAN_INITIAL_STORE_CAPACITY, RESP::value, RedisEntry::value, x_error(), X_GROUP_INVALID, X_NULL, X_SUCCESS, x_trace(), xStringCopyOf(), and xvprintf.

◆ redisxSetScanCount()

int redisxSetScanCount ( Redis redis,
int  count 
)

Sets the COUNT parameter to use with Redis SCAN type commands. COUNT specifies how much work Redis should do in a single scan iteration. 0 (or negative) values can be used to scan with defaults (without the COUNT option), which is usually equivalent to COUNT=10. When scanning large datasets, it may take many scan calls to go through all the data. When networking has limited bandwidth, or large latencies it may be desirable to do more work per call on the server side to reduce traffic. However, the cost of larger COUNT values is that it may increase server latencies for other queries.

Parameters
redisPointer to a Redis instance.
countThe new COUNT to use for SCAN-type commands or <0 to use default.
See also
redisxGetScanCount()
redisxScanKeys()
redisxScanTable()

References X_SUCCESS.

◆ redisxSetValue()

int redisxSetValue ( Redis redis,
const char *  table,
const char *  key,
const char *  value,
boolean  confirm 
)

Sets a global or hashtable value on Redis.

Parameters
redisPointer to a Redis instance.
tableHash table identifier or NULL if setting a global value.
keyRedis field name (i.e. variable name).
valueA proper 0-terminated string value to store.
confirmWhether we should get a confirmation from the server (requires a round-trip).
Returns
X_SUCCESS if the variable was succesfully set, or: X_NO_INIT X_NAME_INVALID X_NULL X_NO_SERVICE X_FAILURE

References Redis::interactive, redisxCheckValid(), redisxLockConnected(), redisxSetValueAsync(), redisxUnlockClient(), and X_SUCCESS.

◆ redisxSetValueAsync()

int redisxSetValueAsync ( RedisClient cl,
const char *  table,
const char *  key,
const char *  value,
boolean  confirm 
)

Sends a request for setting a table value, using the Redis "SET" or "HSET" command.

Parameters
clPointer to a Redis channel.
tableHashtable from which to retrieve a value or NULL if to use the global table.
keyField name (i.e. variable name).
valueThe string value to set (assumes normal string termination).'
confirmWhether confirmation is required from Redis to acknowledge.
Returns
X_SUCCESS (0) if successful, or X_NULL if the client or value is NULL X_NAME_INVALID if key is invalid, or an error (<0) returned by redisxSendRequestAsync().

References redisxCheckRESP(), redisxDestroyRESP(), redisxReadReplyAsync(), redisxSendRequestAsync(), redisxSkipReplyAsync(), RESP_INT, x_error(), X_NAME_INVALID, X_NULL, X_SUCCESS, and xvprintf.