redis 在 php 中的应用(Set篇)

上一篇:redis 在 php 中的应用(List篇)

本文为我阅读了 redis参考手册 之后编写,注意 php_redis 和 redis-cli 的区别(主要是返回值类型和参数用法)

Redis的 Set 是 string 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

目录:

Set(集合)
SADD SREM SMEMBERS SCARD SMOVE SPOP SRANDMEMBER
SINTER SINTERSTORE SUNION0 SUNIONSTORE SDIFF SDIFFSTORE SISMEMBER

Set(集合)

1、SADD

Redis Sadd 命令将一个或多个成员元素加入到集合中

(1)已经存在于集合的成员元素将被忽略。

(2)假如集合 key 不存在,则创建一个只包含添加的元素作成员的集合。

(3)当集合 key 不是集合类型时,返回一个错误。

注意:在Redis2.4版本以前, SADD 只接受单个成员值。

语法:

redis 127.0.0.1:6379> SADD KEY_NAME VALUE1..VALUEN

返回值: 被添加到集合中的新元素的数量,不包括被忽略的元素。

可用版本:>= 1.0.0

时间复杂度:(N),N是被添加的元素的数量。

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘hello‘);    // 已存在的 key 被忽略

var_dump($redis -> sMembers(‘myset‘));
//array (size=2)
//  0 => string ‘hello‘ (length=5)
//  1 => string ‘foo‘ (length=3)

2、SREM

Redis Srem 命令用于移除集合中的一个或多个成员元素,不存在的成员元素会被忽略。

当 key 不是集合类型,返回一个错误。

在 Redis 2.4 版本以前, SREM 只接受单个成员值。

语法:

redis 127.0.0.1:6379> SREM KEY MEMBER1..MEMBERN

返回值: 被成功移除的元素的数量,不包括被忽略的元素。

可用版本:>= 1.0.0

时间复杂度:O(N),N为给定member元素的数量。

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

var_dump($redis -> sRem(‘myset‘,‘hello‘,‘foo‘));    // int 2
var_dump($redis -> sMembers(‘myset‘));
//array (size=3)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘welcome‘ (length=7)
//  2 => string ‘hi‘ (length=2)

3、SMEMBERS

Redis Smembers 命令返回集合中的所有的成员。 不存在的集合 key 被视为空集合。

语法:

redis 127.0.0.1:6379> SMEMBERS KEY VALUE

返回值: 集合中的所有成员。

可用版本:>= 1.0.0

时间复杂度:O(N),N为集合的基数。

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

var_dump($redis -> sMembers(‘myset‘));
//array (size=5)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘hello‘ (length=5)
//  2 => string ‘hi‘ (length=2)
//  3 => string ‘foo‘ (length=3)
//  4 => string ‘welcome‘ (length=7)

4、SCARD

Redis Scard 命令返回集合中元素的数量

语法:

redis 127.0.0.1:6379> SCARD KEY_NAME

返回值:集合的数量。 当集合 key 不存在时,返回 0 。

可用版本:>= 1.0.0

时间复杂度:O(1)

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

var_dump($redis -> sCard(‘myset‘));     // int 5

5、SMOVE

Redis Smove 命令将指定成员 member 元素从 source 集合移动到 destination 集合

(1)SMOVE 是原子性操作。

(2)如果 source 集合不存在或不包含指定的 member 元素,则 SMOVE 命令不执行任何操作,仅返回 0 。否则, member 元素从 source 集合中被移除,并添加到 destination 集合中去。

(3)当 destination 集合已经包含 member 元素时, SMOVE 命令只是简单地将 source 集合中的 member 元素删除。

(4)当 source 或 destination 不是集合类型时,返回一个错误。

语法:

redis 127.0.0.1:6379> SMOVE SOURCE DESTINATION MEMBER

返回值:如果成员元素被成功移除,返回 1 。 如果成员元素不是 source 集合的成员,并且没有任何操作对 destination 集合执行,那么返回 0 。

可用版本:>= 1.0.0

时间复杂度:O(1)

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);
$redis -> sAdd(‘destinationSet‘,‘welcome‘);

// The first case : member 包含在 source 中var_dump($redis -> sMove(‘myset‘,‘destinationSet‘,‘foo‘));  // boolean true
var_dump($redis -> sMembers(‘myset‘));
//array (size=4)
//  0 => string ‘hello‘ (length=5)
//  1 => string ‘hi‘ (length=2)
//  2 => string ‘world‘ (length=5)
//  3 => string ‘welcome‘ (length=7)

// The second case : member 不在 source 中
var_dump($redis -> sMove(‘myset‘,‘destinationSet‘,‘not_exists‘));  // boolean false
var_dump($redis -> sMembers(‘myset‘));
//array (size=4)
//  0 => string ‘hi‘ (length=2)
//  1 => string ‘world‘ (length=5)
//  2 => string ‘hello‘ (length=5)
//  3 => string ‘welcome‘ (length=7)

// The third case : destination 中已经包含 member 元素
var_dump($redis -> sMove(‘myset‘,‘destinationSet‘,‘welcome‘));  // boolean true
var_dump($redis -> sMembers(‘myset‘));          // 只是将 welcome 从 myset 中移除
//array (size=3)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘hello‘ (length=5)
//  2 => string ‘hi‘ (length=2)

6、SPOP

Redis Spop 命令用于移除并返回集合中的一个随机元素。

语法:

redis 127.0.0.1:6379> SPOP KEY

返回值:被移除的随机元素。 当集合不存在或是空集时,返回 nil 。

可用版本:>= 1.0.0

时间复杂度:O(1)

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

// 其值会从原集合中移除
var_dump($redis -> sPop(‘myset‘));      // string world
var_dump($redis -> sMembers(‘myset‘));
//array (size=4)
//  0 => string ‘hi‘ (length=2)
//  1 => string ‘foo‘ (length=3)
//  2 => string ‘hello‘ (length=5)
//  3 => string ‘welcome‘ (length=7)

7、SRANDMEMBER

Redis Srandmember 命令用于返回集合中的一个随机元素

从 Redis 2.6 版本开始, Srandmember 命令接受可选的 count 参数:

  • 如果 count 为正数,且小于集合基数,那么命令返回一个包含 count 个元素的数组,数组中的元素各不相同。如果 count 大于等于集合基数,那么返回整个集合。
  • 如果 count 为负数,那么命令返回一个数组,数组中的元素可能会重复出现多次,而数组的长度为 count 的绝对值。

该操作和 SPOP 相似,但 SPOP 将随机元素从集合中移除并返回,而 Srandmember 则仅仅返回随机元素,而不对集合进行任何改动

语法:

redis 127.0.0.1:6379> SRANDMEMBER KEY [count]

返回值:(1)只提供集合 key 参数时,返回一个元素;

    (2) 如果提供了 count 参数, 若 0<count<集合基数,那么返回一个包含count个元素的数组, 若 count>集合基数,那么返回整个集合

    (3)如果提供了 count 参数, 若 count<0,且 count的绝对值<集合基数,那么返回一个包含count个元素的数组,若 count的绝对值>集合基数,那么返回包含count个元素的数组,元素可能重复出现多次

可用版本:>= 1.0.0

时间复杂度:O(1)

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

// The first case : 当没有 count 参数时,返回一个随机值,其值不会从原集合中移除
var_dump($redis -> sRandMember(‘myset‘));      // string foo
var_dump($redis -> sMembers(‘myset‘));
//array (size=5)
//  0 => string ‘hello‘ (length=5)
//  1 => string ‘hi‘ (length=2)
//  2 => string ‘foo‘ (length=3)
//  3 => string ‘world‘ (length=5)
//  4 => string ‘welcome‘ (length=7)

// The second case : 当 0 < count < 集合基数
var_dump($redis -> sRandMember(‘myset‘,3));   // 返回包含 count 个元素的集合
//array (size=3)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘hello‘ (length=5)
//  2 => string ‘foo‘ (length=3)

// The third case : 当 0 < count 且 集合基数 < count
var_dump($redis -> sRandMember(‘myset‘,10));        // 返回整个集合
//array (size=5)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘hello‘ (length=5)
//  2 => string ‘foo‘ (length=3)
//  3 => string ‘hi‘ (length=2)
//  4 => string ‘welcome‘ (length=7)

// The fourth case : 当 count<0 且  |count| < 集合基数
var_dump($redis -> sRandMember(‘myset‘,-3));       // 返回包含 count 个元素的集合
//array (size=3)
//  0 => string ‘hello‘ (length=5)
//  1 => string ‘welcome‘ (length=7)
//  2 => string ‘world‘ (length=5)

// The fifth case : 当 count<0 且  |count| > 集合基数
var_dump($redis -> sRandMember(‘myset‘,-8));       // 返回包含 count 个元素的集合,有重复
//array (size=8)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘welcome‘ (length=7)
//  2 => string ‘world‘ (length=5)
//  3 => string ‘welcome‘ (length=7)
//  4 => string ‘hello‘ (length=5)
//  5 => string ‘hello‘ (length=5)
//  6 => string ‘world‘ (length=5)
//  7 => string ‘welcome‘ (length=7)

8、SINTER

Redis Sinter 命令返回给定所有给定集合的交集。 不存在的集合 key 被视为空集。 当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。

语法:

redis 127.0.0.1:6379> SINTER KEY KEY1..KEYN

返回值:交集成员的列表。

可用版本:>= 1.0.0

时间复杂度:O(1)

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

$redis -> sAdd(‘otherset‘,‘hello‘);
$redis -> sAdd(‘otherset‘,‘world‘);
$redis -> sAdd(‘otherset‘,‘welcome‘);

// The first case : 集合都不为空 , 原集合不变
var_dump($redis -> sInter(‘myset‘,‘otherset‘));
//array (size=3)
//  0 => string ‘welcome‘ (length=7)
//  1 => string ‘world‘ (length=5)
//  2 => string ‘hello‘ (length=5)

// The second case : 有空集合
var_dump($redis -> sInter(‘myset‘,‘emptyset‘));     // array (size=0) empty

9、SINTERSTORE

Redis Sinterstore 命令将给定集合之间的交集存储在指定的集合中。如果指定的集合已经存在,则将其覆盖。

语法:

redis 127.0.0.1:6379> SINTERSTORE DESTINATION_KEY KEY KEY1..KEYN

返回值:交集成员的列表。

可用版本:>= 1.0.0

时间复杂度:O(N * M),N为给定集合当中基数最小的集合,M为给定集合的个数。

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

$redis -> sAdd(‘otherset‘,‘hello‘);
$redis -> sAdd(‘otherset‘,‘world‘);
$redis -> sAdd(‘otherset‘,‘welcome‘);

$redis -> sAdd(‘other_destinationset‘,‘hello‘);

// The first case : 目标集合不存在
var_dump($redis -> sInterStore(‘destinationset‘,‘myset‘,‘otherset‘));   // int 3
var_dump($redis -> sMembers(‘destinationset‘));
//array (size=3)
//  0 => string ‘welcome‘ (length=7)
//  1 => string ‘world‘ (length=5)
//  2 => string ‘hello‘ (length=5)

// The second case : 目标集合已存在
var_dump($redis -> sInterStore(‘other_destinationset‘,‘myset‘,‘otherset‘));
var_dump($redis -> sMembers(‘other_destinationset‘));       // 覆盖
//array (size=3)
//  0 => string ‘welcome‘ (length=7)
//  1 => string ‘world‘ (length=5)
//  2 => string ‘hello‘ (length=5)

10、SUNION

Redis Sunion 命令返回给定集合的并集。不存在的集合 key 被视为空集。

语法:

redis 127.0.0.1:6379> SUNION KEY KEY1..KEYN

返回值:并集成员的列表。

可用版本:>= 1.0.0

时间复杂度:O(N),N是所有给定集合的成员数量之和

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

$redis -> sAdd(‘otherset‘,‘hello‘);
$redis -> sAdd(‘otherset‘,‘world‘);
$redis -> sAdd(‘otherset‘,‘good‘);

// The first case : 集合都不为空 , 原集合不变
var_dump($redis -> sUnion(‘myset‘,‘otherset‘));
//array (size=6)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘hello‘ (length=5)
//  2 => string ‘welcome‘ (length=7)
//  3 => string ‘good‘ (length=4)
//  4 => string ‘hi‘ (length=2)
//  5 => string ‘foo‘ (length=3)

// The second case : 有空集合
var_dump($redis -> sUnion(‘myset‘,‘emptyset‘));
//array (size=5)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘hello‘ (length=5)
//  2 => string ‘foo‘ (length=3)
//  3 => string ‘hi‘ (length=2)
//  4 => string ‘welcome‘ (length=7)

11、SUNIONSTORE

Redis Sunionstore 命令将给定集合的并集存储在指定的集合 destination 中。如果 destination 已经存在,则将其覆盖。

语法:

redis 127.0.0.1:6379> SUNIONSTORE DESTINATION KEY KEY1..KEYN

返回值:结果集中的元素数量。

可用版本:>= 1.0.0

时间复杂度:O(N),N是所有给定集合的成员数量之和。

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

$redis -> sAdd(‘otherset‘,‘hello‘);
$redis -> sAdd(‘otherset‘,‘world‘);
$redis -> sAdd(‘otherset‘,‘good‘);

$redis -> sAdd(‘other_destinationset‘,‘hello‘);

// The first case : 目标集合不存在
var_dump($redis -> sUnionStore(‘destinationset‘,‘myset‘,‘otherset‘));   // int 6
var_dump($redis -> sMembers(‘destinationset‘));
//array (size=6)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘hello‘ (length=5)
//  2 => string ‘welcome‘ (length=7)
//  3 => string ‘good‘ (length=4)
//  4 => string ‘hi‘ (length=2)
//  5 => string ‘foo‘ (length=3)

// The second case : 目标集合已存在
var_dump($redis -> sUnionStore(‘other_destinationset‘,‘myset‘,‘otherset‘));   // int 6
var_dump($redis -> sMembers(‘other_destinationset‘));       // 覆盖
//array (size=6)
//  0 => string ‘world‘ (length=5)
//  1 => string ‘hello‘ (length=5)
//  2 => string ‘welcome‘ (length=7)
//  3 => string ‘good‘ (length=4)
//  4 => string ‘hi‘ (length=2)
//  5 => string ‘foo‘ (length=3)

12、SDIFF

Redis Sdiff 命令返回给定集合之间的差集。不存在的集合 key 将视为空集。

语法:

redis 127.0.0.1:6379> SDIFF FIRST_KEY OTHER_KEY1..OTHER_KEYN

返回值:包含差集成员的列表。

可用版本:>= 1.0.0

时间复杂度:O(N),N是所有给定集合的成员数量之和。

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

$redis -> sAdd(‘otherset‘,‘hello‘);
$redis -> sAdd(‘otherset‘,‘world‘);
$redis -> sAdd(‘otherset‘,‘good‘);

var_dump($redis -> sDiff(‘myset‘,‘otherset‘));  // 此处的差集指的是第一个集合的元素,不包含后面集合的元素
//array (size=3)
//  0 => string ‘welcome‘ (length=7)
//  1 => string ‘foo‘ (length=3)
//  2 => string ‘hi‘ (length=2)

13、SDIFFSTORE

Redis Sdiffstore 命令将给定集合之间的差集存储在指定的集合中。如果指定的集合 key 已存在,则会被覆盖。

语法:

redis 127.0.0.1:6379> SDIFFSTORE DESTINATION_KEY KEY1..KEYN

返回值:结果集中的元素数量。

可用版本:>= 1.0.0

时间复杂度:O(N),N是所有给定集合的成员数量之和。

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

$redis -> sAdd(‘otherset‘,‘hello‘);
$redis -> sAdd(‘otherset‘,‘world‘);
$redis -> sAdd(‘otherset‘,‘good‘);

$redis -> sAdd(‘other_destinationset‘,‘hello‘);

// The first case : 目标集合不存在
var_dump($redis -> sDiffStore(‘destinationset‘,‘myset‘,‘otherset‘));   // int 3, 此处指的是第一个集合中的元素
var_dump($redis -> sMembers(‘destinationset‘));
//array (size=3)
//  0 => string ‘welcome‘ (length=7)
//  1 => string ‘foo‘ (length=3)
//  2 => string ‘hi‘ (length=2)

// The second case : 目标集合已存在
var_dump($redis -> sDiffStore(‘other_destinationset‘,‘myset‘,‘otherset‘));   // int 3
var_dump($redis -> sMembers(‘other_destinationset‘));       // 覆盖
//array (size=3)
//  0 => string ‘welcome‘ (length=7)
//  1 => string ‘foo‘ (length=3)
//  2 => string ‘hi‘ (length=2)

14、SISMEMBER

Redis Sismember 命令判断成员元素是否是集合的成员。

语法:

redis 127.0.0.1:6379> SISMEMBER KEY VALUE

返回值:如果成员元素是集合的成员,返回 1 。 如果成员元素不是集合的成员,或 key 不存在,返回 0 。

可用版本:>= 1.0.0

时间复杂度:O(1)

具体实例:

<?php
$redis = new redis();
$redis -> connect(‘127.0.0.1‘,6379);
$redis -> flushAll();

$redis -> sAdd(‘myset‘,‘hello‘);
$redis -> sAdd(‘myset‘,‘foo‘);
$redis -> sAdd(‘myset‘,‘world‘);
$redis -> sAdd(‘myset‘,‘hi‘);
$redis -> sAdd(‘myset‘,‘welcome‘);

var_dump($redis -> sIsMember(‘myset‘,‘hello‘));     // true
var_dump($redis -> sIsMember(‘myset‘,‘good‘));      // false

如有转载,请注明出处:http://www.cnblogs.com/chrdai/p/6846352.html

时间: 2024-11-05 17:17:06

redis 在 php 中的应用(Set篇)的相关文章

redis在php中的应用(Trancation篇)

Transaction(事务) 1.WATCH Redis Watch 命令用于监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 语法: redis 127.0.0.1:6379> Watch 返回值: 总是返回 OK  可用版本:>= 2.2.0 时间复杂度:O(1) 具体实例: $redis -> watch('number'); 2.UNWATCH Redis Unwatch 命令用于取消 WATCH 命令对所有 key 的

redis 在 php 中的应用(string篇)

本文为我阅读了 redis参考手册 之后结合 博友的博客 编写,注意 php_redis 和 redis-cli 的区别(主要是返回值类型和参数用法) 上一篇:redis 在 php 中的应用(key篇) 目录: string(字符串) 1.SET Redis SET 命令用于设置给定 key 的值.如果 key 已经存储其他值, SET 就覆写旧值,且无视类型. 语法: redis 127.0.0.1:6379> SET KEY_NAME VALUE 返回值: 设置成功时返回 OK .当sec

redis 在 php 中的应用(Sorted-set篇)

上一篇:redis 在 php 中的应用(Set篇) 本文为我阅读了 redis参考手册 之后编写,注意 php_redis 和 redis-cli 的区别(主要是返回值类型和参数用法) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是通过分数来为集合中的成员进行从小到大的排序. 有序集合的成员是唯一的,但分数(score)却可以重复. 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O

Redis从入门到精通:初级篇

原文链接:http://www.cnblogs.com/xrq730/p/8890896.html,转载请注明出处,谢谢 Redis从入门到精通:初级篇 平时陆陆续续看了不少Redis的文章了,工作中也一直在用Redis,感觉是时候对过往Redis的所学进行一次系统性的总结.<Redis从入门到精通>系列会分为初级.中级.高级三篇,从浅入深讲解Redis相关知识点. 在本文中,我们将看到以下内容: Redis简介 Redis安装.启动 Redis登录授权 Redis配置文件redis.conf

Redis从入门到精通:中级篇

原文链接:http://www.cnblogs.com/xrq730/p/8944539.html,转载请注明出处,谢谢 本文目录 上一篇文章以认识Redis为主,写了Redis系列的第一篇,现在开启第二部分的学习,在本文中,我们将看到以下内容: Redis数据结构String.Hash.List.Set.SortedSet及相关操作,提一下Redis在3.2.0之后有新增了一种GEO的数据类型表示地理位置,不过本文这种数据结构略过 Redis其他一些常用命令,分为Key操作与服务器操作 Red

Redis源码中探秘SHA-1算法原理及其编程实现

导读 SHA-1算法是第一代"安全散列算法"的缩写,其本质就是一个Hash算法.SHA系列标准主要用于数字签名,生成消息摘要,曾被认为是MD5算法的后继者.如今SHA家族已经出现了5个算法.Redis使用的是SHA-1,它能将一个最大2^64比特的消息,转换成一串160位的消息摘要,并能保证任何两组不同的消息产生的消息摘要是不同的.虽然SHA1于早年间也传出了破解之道,但作为SHA家族的第一代算法,对我们仍然很具有学习价值和指导意义. SHA-1算法的详细内容可以参考官方的RFC:ht

认识元数据和IL(中)&lt;第四篇&gt;

书接上回[第二十四回:认识元数据和IL(上)],我们对PE文件.程序集.托管模块,这些概念与元数据.IL的关系进行了必要的铺垫,同时顺便熟悉了以ILDASM工具进行反编译的基本方法认知,下面是时候来了解什么是元数据,什么是IL这个话题了,我们继续. 很早就有说说Metadata(元数据)和IL(中间语言)的想法了,一直在这篇开始才算脚踏实地的对这两个阶级兄弟投去些细关怀,虽然来得没有<第一回:恩怨情仇:is和as>那么迅速,但是Metadata和IL却是绝对重量级的内容,值得我们在任何时间关注

在Visual Studio中使用GitHub(使用篇)

一.准备工具 上一篇中我们已经安装了Git Extensions和Tortoisegit.在这里我们要为Visual Studio安装一个插件,专门用于Git. Git Source Control Provider,打开http://visualstudiogallery.msdn.microsoft.com/ 搜索"Git"关键字,即可搜索到该插件. 二.配置源码管理工具 三.配置帐户关联 四.使用 后面的事情就很简单了,创建文件夹 pull 一个副本,修改文件,commit文件,

视觉SLAM中的数学基础 第二篇 四元数

视觉SLAM中的数学基础 第二篇 四元数 什么是四元数 相比欧拉角,四元数(Quaternion)则是一种紧凑.易于迭代.又不会出现奇异值的表示方法.它在程序中广为使用,例如ROS和几个著名的SLAM公开数据集.g2o等程序都使用四元数记录机器人的姿态.因此,理解四元数的含义与用法,对学习SLAM来说是必须的.本节我们就来讲讲四元数. 首先,请读者不要对四元数有什么神秘的感觉.四元数仅是3D姿态的一种表达方式,我们用一个单位四元数表达原本用旋转矩阵表示的三维旋转.这样做一个直接的好处是省空间.一