acl/lib_acl_cpp/include/acl_cpp/redis/redis_hash.hpp

225 lines
8.2 KiB
C++
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#pragma once
#include "acl_cpp/acl_cpp_define.hpp"
#include <map>
#include <vector>
#include "acl_cpp/stdlib/string.hpp"
#include "acl_cpp/redis/redis_command.hpp"
namespace acl
{
class redis_client;
class redis_result;
/**
* redis Hahs(哈希表) 类,本类的实现的主要命令:
* HDEL/HEXISTS/HGET/HGETALL/HINCRBY/HINCRBYFLOAT/HKEYS/HLEN/HMGET/HMSET
* HSET/HSETNX/HVALS/HSCAN
*/
class ACL_CPP_API redis_hash : virtual public redis_command
{
public:
/**
* see redis_command::redis_command()
*/
redis_hash();
/**
* see redis_command::redis_command(redis_client*)
*/
redis_hash(redis_client* conn);
/**
* see redis_command::redis_command(redis_client_cluster* size_t)
*/
redis_hash(redis_client_cluster* cluster, size_t max_conns);
virtual ~redis_hash();
/////////////////////////////////////////////////////////////////////
/**
* 将多个"域-值"对添加至 KEY 对应的哈希表中
* @param key {const char*} 哈希表 key 值
* @return {bool} 添加是否成功
*/
bool hmset(const char* key, const std::map<string, string>& attrs);
bool hmset(const char* key, const std::map<string, const char*>& attrs);
/////////////////////////////////////////////////////////////////////
/**
* 根据 KEY 值将多个"域-值"对从哈希表中取出
* @param key {const char*} 哈希表 key 值
* @param names 对应 key 的域值对
* @param result {std::vector<string>*} 当该对象指针非空时存储查询结果;
* 如果该参数为 NULL 时,则可以通过基类 get_
* @return {bool} 操作是否成功,操作成功后可以通过以下任一种方式获得数据:
* 1、基类方法 get_value 获得指定下标的元素数据
* 2、基类方法 get_child 获得指定下标的元素对象(redis_result然后再通过
* redis_result::argv_to_string 方法获得元素数据
* 3、基类方法 get_result 方法取得总结果集对象 redis_result然后再通过
* redis_result::get_child 获得一个元素对象,然后再通过方式 2 中指定
* 的方法获得该元素的数据
* 4、基类方法 get_children 获得结果元素数组对象,再通过 redis_result 中
* 的方法 argv_to_string 从每一个元素对象中获得元素数据
* 5、在调用方法中传入非空的存储结果对象的地址
*/
bool hmget(const char* key, const std::vector<string>& names,
std::vector<string>* result = NULL);
bool hmget(const char* key, const std::vector<const char*>& names,
std::vector<string>* result = NULL);
bool hmget(const char* key, const char* names[], size_t argc,
std::vector<string>* result = NULL);
bool hmget(const char* key, const char* names[], const size_t lens[],
size_t argc, std::vector<string>* result = NULL);
/////////////////////////////////////////////////////////////////////
/**
* 设置 key 对象中某个域字段的值
* @param key {const char*} key 键值
* @param name {const char*} key 对象的域名称
* @param value {const char*} key 对象的域值
* @return {int} 返回值含义:
* 1 -- 表示新添加的域字段添加成功
* 0 -- 表示更新已经存在的域字段成功
* -1 -- 表示出错或该 key 对象非哈希对象或从结点禁止修改
*/
int hset(const char* key, const char* name, const char* value);
int hset(const char* key, const char* name,
const char* value, size_t value_len);
int hset(const char* key, const char* name, size_t name_len,
const char* value, size_t value_len);
/**
* 当且仅当 key 对象中的某个域字段不存在时才更新该域字段值
* @param key {const char*} key 键值
* @param name {const char*} key 对象的域名称
* @param value {const char*} key 对象的域值
* @return {int} 返回值含义:
* 1 -- 表示新添加的域字段添加成功
* 0 -- 该域字段存在且未对其进行更新
* -1 -- 表示出错或该 key 对象非哈希对象或从结点禁止修改
*/
int hsetnx(const char* key, const char* name, const char* value);
int hsetnx(const char* key, const char* name,
const char* value, size_t value_len);
int hsetnx(const char* key, const char* name, size_t name_len,
const char* value, size_t value_len);
/**
* 从 redis 哈希表中获取某个 key 对象的某个域的值
* @param key {const char*} key 键值
* @param name {const char*} key 对象的域字段名称
* @param result {string&} 存储查询结果值(内部对该 string 进行内容追加)
* @return {bool} 返回值含义:
* true -- 操作成功,当该域不存在时也返回成功,需要检查 result 内容是否变化,
* 比如可以通过检查 result.length() 的变化来表明是否查询到结果
* false -- 操作失败或该 key 对象非哈希对象
*/
bool hget(const char* key, const char* name, string& result);
bool hget(const char* key, const char* name,
size_t name_len, string& result);
/**
* 从 redis 哈希表中获取某个 key 对象的所有域字段的值
* @param key {const char*} key 键值
* @param result {std::map<string, string>&} 存储域字段名-值查询结果集
* @return {bool} 操作是否成功,含义:
* true -- 操作成功,当该域不存在时也返回成功,需要检查 result 内容是否变化,
* 比如可以通过检查 result.size() 的变化来表明是否查询到结果
* false -- 操作失败或该 key 对象非哈希对象
*/
bool hgetall(const char* key, std::map<string, string>& result);
bool hgetall(const char* key, std::vector<string>& names,
std::vector<string>& values);
bool hgetall(const char* key, std::vector<const char*>& names,
std::vector<const char*>& values);
/**
* 从 redis 哈希表中删除某个 key 对象的某些域字段
* @param key {const char*} key 键值
* @param first_name {const char*} 第一个域字段名,最后一个字段必须是 NULL
* @return {int} 成功删除的域字段个数,返回 -1 表示出错或该 key 对象非哈希对象
*/
int hdel(const char* key, const char* first_name, ...);
int hdel(const char* key, const char* names[], size_t argc);
int hdel(const char* key, const char* names[],
const size_t names_len[], size_t argc);
int hdel(const char* key, const std::vector<string>& names);
int hdel(const char* key, const std::vector<const char*>& names);
/**
* 当某个 key 对象中的某个域字段为整数时,对其进行加减操作
* @param key {const char*} key 键值
* @param name {const char*} key 对象的域字段名称
* @param inc {long long int} 增加的值,可以为负值
* @param result {long long int*} 非 NULL 时存储结果值
* @return {bool} 操作是否成功,当返回 false 时表明出错或该 key 对象非哈希
* 对象或该域字段非整数类型
*/
bool hincrby(const char* key, const char* name,
long long int inc, long long int* result = NULL);
/**
* 当某个 key 对象中的某个域字段为浮点数时,对其进行加减操作
* @param key {const char*} key 键值
* @param name {const char*} key 对象的域字段名称
* @param inc {double} 增加的值,可以为负值
* @param result {double*} 非 NULL 时存储结果值
* @return {bool} 操作是否成功,当返回 false 时表明出错或该 key 对象非哈希
* 对象或该域字段非浮点数类型
*/
bool hincrbyfloat(const char* key, const char* name,
double inc, double* result = NULL);
/**
* 返回 key 对象中所有域字段名称
* @param key {const char*} key 键值
* @param names {std::vector<string>&} 存储该 key 对象所有域字段名称
* @return {bool} 操作是否成功,返回 false 表明出错或该 key 对象非哈希对象
*/
bool hkeys(const char* key, std::vector<string>& names);
/**
* 检查 key 对象中某个域字段是否存在
* @param key {const char*} key 键值
* @param name {const char*} key 对象的域字段名称
* @return {bool} 操作是否成功,返回 false 表明出错或该 key 对象非哈希对象
* 或该域字段不存在
*/
bool hexists(const char* key, const char* name);
bool hexists(const char* key, const char* name, size_t name_len);
/**
* 获得某个 key 对象中所有域字段的数量
* @param key {const char*} key 键值
* @return {int} 返回值含义:
* -1 -- 出错或该 key 对象非哈希对象
* >0 -- 域字段数量
* 0 -- 该 key 不存在或域字段数量为 0
*/
int hlen(const char* key);
/**
* 命令用于迭代哈希键中的键值对
* @param key {const char*} 哈希键值
* @param cursor {int} 游标值,开始遍历时该值写 0
* @param out {std::map<string>&} 存储结果集,内部以追加方式将本次
* 遍历结果添加进该对象中,为防止因总结果集过大导致该数组溢出,用户可在
* 调用本函数前后清理该对象
* @param pattern {const char*} 匹配模式glob 风格,非空时有效
* @param count {const size_t*} 限定的结果集数量,非空指针时有效
* @return {int} 下一个游标位置,含义如下:
* 0遍历结束
* -1: 出错
* >0: 游标的下一个位置
*/
int hscan(const char* key, int cursor, std::map<string, string>& out,
const char* pattern = NULL, const size_t* count = NULL);
};
} // namespace acl