目次
媒介:
set
sadd sismember smembers
spop scard
sinter sinterstore
zset
zadd zrange zcard
zrem zrank zscore
媒介:
前文我们已经先容了string list hash在Redis-plus-plus的使用,本文我们开始先容set和zset在redis-plus-plus的使用。
本文作为Redis初阶的一个收尾,先容完对应的使用之后,我们就可以进入到Redis的底层原理了。
set
sadd sismember smembers
对于sadd来说,它就是set add的意思嘛,在命令行中,我们可以直接sadd key v1 v2 v3,在这里,我们可以单次插入,也可以是初始化列表,也可以是迭代器,它的讨论和前面的list险些是一样的。对于sismember来说,就是判定value是否在key里面,命令行的用法是sismember key member,这里其实用法也是,不过我们必要用bool类型接受而已。对于smembers来说,就是用来得到所有的member的,按照之前的套路,我们必要用一个迭代器来带出对应的member:
- void test_1(Redis &redis)
- {
- redis.flushall();
- redis.sadd("key","1");
- redis.sadd("key",{"2", "3"});
- std::vector<std::string> vec{"4","5"};
- redis.sadd("key",vec.begin(), vec.end());
- bool ans = redis.sismember("key", "3");
- if(ans) std::cout << "is member" << std::endl;
- else std::cout << "not member" << std::endl;
- auto iter = std::inserter(vec, vec.end());
- redis.smembers("key", iter);
-
- for(auto e : vec)
- std::cout << e << " ";
- std::cout << std::endl;
- }
复制代码
spop scard
我们仍然要留意一个点是,set的删除是随即删除的,以是我们删除的时间是没有办法指定的,对于scard,它就是一个用来计数的,代码如下:
- void test_2(Redis &redis)
- {
- redis.flushall();
- redis.sadd("key","1");
- redis.sadd("key",{"2", "3"});
-
- auto ans = redis.spop("key");
- if(ans) std::cout << ans.value() << std::endl;
- else std::cout << "set is empty" << std::endl;
-
- long long res = redis.scard("key");
- std::cout << res << std::endl;
- }
复制代码
sinter sinterstore
在命令行中,使用sinter是直接返回交集的结果,在redis-plus-plus中,我们可以将结果存储到一个容器里面,sinterstore是可以将结果存储到另一个key中,不过是存储的位置不同罢了。
- void test_3(Redis &redis)
- {
- redis.flushall();
- redis.sadd("key", "1");
- redis.sadd("key", {"2", "3"});
- redis.sadd("key1", {"1", "2", "4"});
-
- std::vector<std::string> vec;
- auto iter = std::back_inserter(vec);
- redis.sinter({"key", "key1"}, iter);
- for(auto e : vec)
- std::cout << e << " ";
- std::cout << std::endl;
- }
复制代码
- void test_4(Redis &redis)
- {
- redis.flushall();
- redis.sadd("key", "1");
- redis.sadd("key", {"2", "3"});
- redis.sadd("key1", {"1", "2", "4"});
-
- long long n = redis.sinterstore("key2", {"key", "key1"});
- std::cout << n << std::endl;
-
- std::vector<std::string> vec;
- auto iter = std::back_inserter(vec);
- redis.smembers("key2", iter);
- for(auto e : vec)
- std::cout << e << " ";
- std::cout << std::endl;
- }
复制代码
对于set的交集并集差集都是一样的,以是这里我们就使用交集来先容了,其他的两个我们完全可以依次类推。
zset
对于zset来说,相对就要麻烦一点,因为它的查询,就会带着两种风格举行查询,一种是带着score的,一种是不带着score的,并且因为分数的存在,就还可以引入排名,虽然是分数的附属品,但是也为zset的难度增加了一点。
zadd zrange zcard
- void test_1(Redis &redis)
- {
- redis.flushall();
- redis.zadd("key", "zhangsan",10);
- redis.zadd("key", {std::make_pair("wangwu",30),std::make_pair("lisi",20)});
- std::vector<std::pair<std::string, double>> vec{
- std::make_pair("zhaoliu",40),
- std::make_pair("tianqi",50)
- };
- redis.zadd("key", vec.begin(), vec.end());
- std::vector<std::pair<std::string, double>> ans;
- auto res = std::back_inserter(ans);
- redis.zrange("key", 0, -1, res);
- for(auto e : ans)
- std::cout << e.first << ":" << e.second<< std::endl;
- std::cout << redis.zcard("key") << std::endl;
- }
复制代码
不过大家把这段代码放在自己的机器上跑可能会出题目,因为对于zrange来说,旧版本的redis是可以直接不消参数,直接带分数返回的,但是新版本的必要带上第五个参数true。
zrem zrank zscore
对于zrem来说,就是删除元素,不过它和set不同的是它可以指定元素删除,对于zrank就是返回排名,对于zscore来说就是返回对应的分数:
- void test_2(Redis &redis)
- {
- redis.flushall();
- redis.zadd("key", "zhangsan",10);
- redis.zadd("key", {std::make_pair("wangwu",30),std::make_pair("lisi",20)});
- redis.zrem("key", "zhangsan");
- long long n = redis.zcard("key");
- std::cout << n << std::endl;
- auto ans = redis.zscore("key", "lisi");
- if(ans) std::cout << ans.value() << std::endl;
- else std::cout << "not exist" << std::endl;
- auto res = redis.zrank("key", "lisi");
- if(res) std::cout << res.value() << std::endl;
- else std::cout << "not exist" << std::endl;
- }
复制代码
固然了,zset的操作远不止于此,不过很多类似的操作我们已经通过string list等其他先容过了,好比zadd的NX和XX,我们自己清楚就行,用到的时间着实忘了,咱们再看也不迟~~
那么,基本的命令部分,我们就算是正式完结啦!
gogogo , 进入到原理部分咯~
感谢阅读!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |