Redis::__construct
描述:
创建一个Redis客户端
范例:
$redis = new Redis();
 
connect, open
描述:
实例连接到一个Redis.
参数:host: string        port: int
返回值:BOOL 成功返回:TRUE;失败返回:FALSE
范例:
$redis->connect('127.0.0.1′, 6379);
 
get
描述:
获取有关指定键的值
参数:key
返回值:string或BOLL 如果键不存在,则返回 FALSE。否则,与此相关的关键值返回。
范例:
$redis->get('key');
 
set
描述:
设置关键值参数
参数:Key Value
返回值:BOOL
范例:
$redis->set('key', 'value')
 
setnx
描述:
如果在数据库中不存在该键,设置关键值参数
参数:key value
返回值:BOOL
范例:
$this->redis->setnx('key', 'value');
$this->redis->setnx('key', 'value');
 
delete
描述:
删除指定的键
参数:一个键,或不确定数目的参数,每一个关键的数组:key1 key2 key3 … keyN
返回值:删除的项数
范例:
$redis->set('key1′, 'val1′);
$redis->set('key2′, 'val2′);
$redis->set('key3′, 'val3′);
$redis->set('key4′, 'val4′);
$redis->delete('key1′, 'key2′);
$redis->delete(array('key3′, 'key4′));
 
exists
描述:
验证指定的键是否存在
参数key
返回值:Bool
范例:
$this->set('key', 'value');
$this->exists('key');
$this->exists('NonExistingKey');
 
incr
描述:
数字递增存储键值键.如果第二个参数被填满,它将被用来作为整数值递增
Increment the number stored at key by one. If the second argument is filled, it will be used as the integer value of the increment.
参数:key value:将被添加到键的值
返回值:INT the new value
范例:
$redis->incr('key1′);
 
 
$redis->incr('key1′);
$redis->incr('key1′);
$redis->incr('key1′);
 
decr
描述:
数字递减存储键值。如果第二个参数被填满,它将被用来作为整数值递减
Decrement the number stored at key by one. If the second argument is filled, it will be used as the integer value of the decrement.
参数:key value:将被添加到键的值
返回值:INT the new value
范例:
$redis->decr('key1′);
 
$redis->decr('key1′);
$redis->decr('key1′);
 
getMultiple
描述:
取得所有指定键的值。如果一个或多个键不存在,该数组中该键的值为假
参数:其中包含键值的列表数组
返回值:返回包含所有键的值的数组
范例:
$redis->set('key1′, 'value1′);
$redis->set('key2′, 'value2′);
$redis->set('key3′, 'value3′);
$redis->getMultiple(array('key1′, 'key2′, 'key3′));
 
rPush
描述:
由列表头部添加字符串值。如果不存在该键则创建该列表。如果该键存在,而且不是一个列表,返回FALSE。
参数:key,value
返回值:LONG The new length of the list in case of success, FALSE in case of Failure.
范例:
$redis->delete('key1′);
$redis->lPush('key1′, 'C'); // returns 1
$redis->lPush('key1′, 'B'); // returns 2
$redis->lPush('key1′, 'A'); // returns 3
 
 
lPop
描述:
返回和移除列表的最后一个元素
参数:key
返回值:STRING if command executed successfully BOOL FALSE in case of failure (empty list)
范例:
$redis->rPush('key1′, 'A');
$redis->rPush('key1′, 'B');
$redis->rPush('key1′, 'C');
$redis->lPop('key1′);
 
rPop
描述:
返回和移除列表的第一个元素
参数:key
返回值:STRING if command executed successfully BOOL FALSE in case of failure (empty list)
范例:
$redis->rPush('key1′, 'A');
$redis->rPush('key1′, 'B');
$redis->rPush('key1′, 'C');
$redis->rPop('key1′);
 
lSize
描述:
返回的列表的大小。如果列表不存在或为空,该命令返回0。如果该键不是列表,该命令返回FALSE。
参数:Key
返回值:
LONG The size of the list identified by Key exists.
BOOL FALSE if the data type identified by Key is not list
范例:
$redis->rPush('key1′, 'A');
$redis->rPush('key1′, 'B');
$redis->rPush('key1′, 'C');
$redis->lSize('key1′);
$redis->rPop('key1′);
$redis->lSize('key1′);
 
lGet
描述:
返回指定键存储在列表中指定的元素。 0第一个元素,1第二个… -1最后一个元素,-2的倒数第二…错误的索引或键不指向列表则返回FALSE。
参数:key index
返回值:
String the element at this index
Bool FALSE if the key identifies a non-string data type, or no value corresponds to this index in the list Key.
范例:
$redis->rPush('key1′, 'A');
$redis->rPush('key1′, 'B');
$redis->rPush('key1′, 'C');
$redis->lGet('key1′, 0);
$redis->lGet('key1′, -1);
$redis->lGet('key1′, 10);
 
lSet
描述:
为列表指定的索引赋新的值,若不存在该索引返回false.
参数:key index value
返回值:BOOL TRUE if the new value is setted. FALSE if the index is out of range, or data type identified by key is not a list.
范例:
$redis->rPush('key1′, 'A');
$redis->rPush('key1′, 'B');
$redis->rPush('key1′, 'C');
$redis->lGet('key1′, 0);
$redis->lSet('key1′, 0, 'X');
$redis->lGet('key1′, 0);
 
lGetRange
描述:
返回在该区域中的指定键列表中开始到结束存储的指定元素,lGetRange(key, start, end)。0第一个元素,1第二个元素… -1最后一个元素,-2的倒数第二…
参数:key start end
返回值:
Array containing the values in specified range.
范例:
$redis->rPush('key1′, 'A');
$redis->rPush('key1′, 'B');
$redis->rPush('key1′, 'C');
$redis->lGetRange('key1′, 0, -1);
lRemove
描述:
从列表中从头部开始移除count个匹配的值。如果count为零,所有匹配的元素都被删除。如果count是负数,内容从尾部开始删除。
参数:key count value
返回值:
LONG the number of elements to remove
BOOL FALSE if the value identified by key is not a list.
范例:
$redis->lPush('key1′, 'A');
$redis->lPush('key1′, 'B');
$redis->lPush('key1′, 'C');
$redis->lPush('key1′, 'A');
$redis->lPush('key1′, 'A');
$redis->lGetRange('key1′, 0, -1);
$redis->lRemove('key1′, 'A', 2);
$redis->lGetRange('key1′, 0, -1);
 
sAdd
描述:
为一个Key添加一个值。如果这个值已经在这个Key中,则返回FALSE。
参数:key value
返回值:
BOOL TRUE if value didn't exist and was added successfully, FALSE if the value is already present.
范例:
$redis->sAdd('key1′ , 'set1′);
$redis->sAdd('key1′ , 'set2′);
$redis->sAdd('key1′ , 'set2′);
 
sRemove
描述:
删除Key中指定的value值
参数:key member
返回值:BOOL TRUE if the member was present in the set, FALSE if it didn't.
范例:
$redis->sAdd('key1′ , 'set1′);
$redis->sAdd('key1′ , 'set2′);
$redis->sAdd('key1′ , 'set3′);
$redis->sRemove('key1′, 'set2′);
 
sMove
描述:
将Key1中的value移动到Key2中
参数:srcKey dstKey member
返 回值:BOOL If the operation is successful, return TRUE. If the srcKey and/or dstKey didn't exist, and/or the member didn't exist in srcKey, FALSE is returned.
范例:
$redis->sAdd('key1′ , 'set11′);
$redis->sAdd('key1′ , 'set12′);
$redis->sAdd('key1′ , 'set13′);
$redis->sAdd('key2′ , 'set21′);
$redis->sAdd('key2′ , 'set22′);
$redis->sMove('key1′, 'key2′, 'set13′);
 
 
sContains
描述:
检查集合中是否存在指定的值。
参数:key value
返回值:BOOL TRUE if value is a member of the set at key key, FALSE otherwise.
范例:
$redis->sAdd('key1′ , 'set1′);
$redis->sAdd('key1′ , 'set2′);
$redis->sAdd('key1′ , 'set3′);
$redis->sContains('key1′, 'set1′);
$redis->sContains('key1′, 'setX');
 
sSize
描述:
返回集合中存储值的数量
参数:key
返回值:LONG the cardinality of the set identified by key, 0 if the set doesn't exist.
范例:
$redis->sAdd('key1′ , 'set1′);
$redis->sAdd('key1′ , 'set2′);
$redis->sAdd('key1′ , 'set3′);
$redis->sSize('key1′);
$redis->sSize('keyX');
 
sPop
描述:
随机移除并返回key中的一个值
参数:key
返回值:String "popped" value        Bool FALSE if set identified by key is empty or doesn't exist.
范例:
$redis->sAdd('key1′ , 'set1′);
$redis->sAdd('key1′ , 'set2′);
$redis->sAdd('key1′ , 'set3′);
$redis->sPop('key1′);
$redis->sPop('key1′);
 
sInter
描述:
返回一个所有指定键的交集。如果只指定一个键,那么这个命令生成这个集合的成员。如果不存在某个键,则返回FALSE。
参数:key1, key2, keyN: keys identifying the different sets on which we will apply the intersection.
返 回值:Array, contain the result of the intersection between those keys. If the intersection beteen the different sets is empty, the return value will be empty array.
范例:
$redis->sAdd('key1′, 'val1′);
$redis->sAdd('key1′, 'val2′);
$redis->sAdd('key1′, 'val3′);
$redis->sAdd('key1′, 'val4′);
$redis->sAdd('key2′, 'val3′);
$redis->sAdd('key2′, 'val4′);
$redis->sAdd('key3′, 'val3′);
$redis->sAdd('key3′, 'val4′);
var_dump($redis->sInter('key1′, 'key2′, 'key3′));
输出:
array(2) {[0]=>string(4) "val4″ [1]=>string(4) "val3″}
 
sInterStore
描述:
执行sInter命令并把结果储存到新建的变量中。
参数:
Key: dstkey, the key to store the diff into.
Keys: key1, key2… keyN. key1..keyN are intersected as in sInter.
返回值:INTEGER: The cardinality of the resulting set, or FALSE in case of a missing key.
范例:
$redis->sAdd('key1′, 'val1′);
$redis->sAdd('key1′, 'val2′);
$redis->sAdd('key1′, 'val3′);
$redis->sAdd('key1′, 'val4′);
$redis->sAdd('key2′, 'val3′);
$redis->sAdd('key2′, 'val4′);
$redis->sAdd('key3′, 'val3′);
$redis->sAdd('key3′, 'val4′);
var_dump($redis->sInterStore('output', 'key1′, 'key2′, 'key3′));
var_dump($redis->sMembers('output'));
输出:
int(2)
array(2) {
[0]=>
string(4) "val4″
[1]=>
string(4) "val3″
}
 
sUnion
描述:
返回一个所有指定键的并集
参数:
Keys: key1, key2, … , keyN: Any number of keys corresponding to sets in redis.
返回值:
Array of strings: The union of all these sets.
范例:
$redis->delete('s0′, 's1′, 's2′);
$redis->sAdd('s0′, '1′);
$redis->sAdd('s0′, '2′);
$redis->sAdd('s1′, '3′);
$redis->sAdd('s1′, '1′);
$redis->sAdd('s2′, '3′);
$redis->sAdd('s2′, '4′);
var_dump($redis->sUnion('s0′, 's1′, 's2′));
输出:
array(4) {
[0]=>
string(1) "3″
[1]=>
string(1) "4″
[2]=>
string(1) "1″
[3]=>
string(1) "2″
}
 
sUnionStore
描述:
执行sUnion命令并把结果储存到新建的变量中。
参数:
Key: dstkey, the key to store the diff into.
Keys: key1, key2, … , keyN: Any number of keys corresponding to sets in redis.
返回值:
INTEGER: The cardinality of the resulting set, or FALSE in case of a missing key.
范例:
$redis->delete('s0′, 's1′, 's2′);
$redis->sAdd('s0′, '1′);
$redis->sAdd('s0′, '2′);
$redis->sAdd('s1′, '3′);
$redis->sAdd('s1′, '1′);
$redis->sAdd('s2′, '3′);
$redis->sAdd('s2′, '4′);
var_dump($redis->sUnionStore('dst', 's0′, 's1′, 's2′));
var_dump($redis->sMembers('dst'));
输出:
int(4)
array(4) {
[0]=>
string(1) "3″
[1]=>
string(1) "4″
[2]=>
string(1) "1″
[3]=>
string(1) "2″
}
 
sDiff
描述:
返回第一个集合中存在并在其他所有集合中不存在的结果
参数:Keys: key1, key2, … , keyN: Any number of keys corresponding to sets in redis.
返回值:Array of strings: The difference of the first set will all the others.
范例:
$redis->delete('s0′, 's1′, 's2′);
$redis->sAdd('s0′, '1′);
$redis->sAdd('s0′, '2′);
$redis->sAdd('s0′, '3′);
$redis->sAdd('s0′, '4′);
$redis->sAdd('s1′, '1′);
$redis->sAdd('s2′, '3′);
var_dump($redis->sDiff('s0′, 's1′, 's2′));
array(2) {
[0]=>
string(1) "4″
[1]=>
string(1) "2″
}
 
sDiffStore
描述:
执行sDiff命令并把结果储存到新建的变量中。
参数:
Key: dstkey, the key to store the diff into.
Keys: key1, key2, … , keyN: Any number of keys corresponding to sets in redis
返回值:INTEGER: The cardinality of the resulting set, or FALSE in case of a missing key.
范例:
$redis->delete('s0′, 's1′, 's2′);
$redis->sAdd('s0′, '1′);
$redis->sAdd('s0′, '2′);
$redis->sAdd('s0′, '3′);
$redis->sAdd('s0′, '4′);
$redis->sAdd('s1′, '1′);
$redis->sAdd('s2′, '3′);
var_dump($redis->sDiffStore('dst', 's0′, 's1′, 's2′));
var_dump($redis->sMembers('dst'));
Return value: the number of elements of s0 that are neither in s1 nor in s2.
int(2)
array(2) {
[0]=>
string(1) "4″
[1]=>
string(1) "2″
}
 
sMembers, sGetMembers
描述:
返回集合的内容
参数:Key: key
返回值:An array of elements, the contents of the set.
范例:
$redis->delete('s');
$redis->sAdd('s', 'a');
$redis->sAdd('s', 'b');
$redis->sAdd('s', 'a');
$redis->sAdd('s', 'c');
var_dump($redis->sMembers('s'));
Output:
array(3) {
[0]=>
string(1) "c"
[1]=>
string(1) "a"
[2]=>
string(1) "b"
}
 
getSet
描述:
返回当前的Key的值,并修改Key为新的值。
参数:
Key: key
STRING: value
返回值:
A string, the previous value located at this key.
范例:
$redis->set('x', '42′);
$exValue = $redis->getSet('x', 'lol'); // return '42′, replaces x by 'lol'
$newValue = $redis->get('x')' // return 'lol'
Redis根本是使用内存存储,持久化的关键是这三条指令:SAVE BGSAVE LASTSAVE …
当接收到SAVE指令的时候,Redis就会dump数据到一个文件里面。
值得一说的是它的独家功能:存储列表和集合,这是它与mc之流相比更有竞争力的地方。
不介绍mc里面已经有的东东,只列出特殊的:
TYPE key — 用来获取某key的类型
KEYS pattern — 匹配所有符合模式的key,太淫荡了,比如KEYS * 就列出所有的key了,当然,复杂度O(n)
RANDOMKEY - 返回随机的一个keyRENAME oldkey newkey — key也可以改名
列表操作,精华
RPUSH key string — 将某个值加入到一个key列表头部
LPUSH key string — 将某个值加入到一个key列表末尾
LLEN key — 列表长度
LRANGE key start end — 返回列表中某个范围的值,相当于mysql里面的分页查询那样
LTRIM key start end — 只保留列表中某个范围的值
LINDEX key index — 获取列表*****定索引号的值,要注意是O(n)复杂度
LSET key index value — 设置列表中某个位置的值
LPOP key
RPOP key — 和上面的LPOP一样,就是类似栈或队列的那种取头取尾指令,可以当成消息队列来使用了
集合操作
SADD key member — 增加元素
SREM key member — 删除元素
SCARD key — 返回集合大小
SISMEMBER key member — 判断某个值是否在集合中
SINTER key1 key2 ... keyN — 获取多个集合的交集元素
SMEMBERS key — 列出集合的所有元素
 
 
 
以下转自 http://bbs.linuxtone.org/thread-7136-1-1.html
 
操作hash类型的值:
Command                Parameters             Description 
HSET                          key field value         Set the hash field to the specified value. Creates the hash if needed. 
HGET                          key field                 Retrieve the value of the specified hash field. 
HMGET                       key field1 ... fieldN   Get the hash values associated to the specified fields. 
HMSET                       key field1 value1 ... fieldN valueN     Set the hash fields to their respective values. 
HINCRBY                    key field integer       Increment the integer value of the hash at key on field with integer. 
HEXISTS                    key field                 Test for existence of a specified field in a hash 
HDEL                         key field                 Remove the specified field from a hash 
HLEN                         key                        Return the number of items in a hash. 
HKEYS                       key                        Return all the fields in a hash. 
HVALS                       key                       Return all the values in a hash. 
HGETALL                   key                        Return all the fields and associated values in a hash.
 
 
HSET操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hset h_uid uid001 'Falcon.C'
(integer) 1
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hset h_uid uid002 'NetSeek' 
(integer) 1
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hset h_uid uid003 'LinuxTone'
(integer) 1
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hkeys h_uid
1. "uid001"
2. "uid002"
3. "uid003"
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hvals h_uid
1. "Falcon.C"
2. "NetSeek"
3. "LinuxTone"
复制代码
表示给指定的hash字段设置值,如果不存在则创建
 
HGET操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hget h_uid uid001
"Falcon.C"
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hget h_uid uid002
"NetSeek"
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hget h_uid uid003
"LinuxTone"
复制代码
表示获取指定hash字段的值
 
HMGET操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hmget h_uid uid001 uid002 uid003
1. "Falcon.C"
2. "NetSeek"
3. "LinuxTone"
复制代码
表示批量获取指定hash字段的值
 
HMSET操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hmset h_uid uid004 'linuxtone.org' uid005 'qq.com'
OK
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hkeys h_uid
1. "uid001"
2. "uid002"
3. "uid003"
4. "uid004"
5. "uid005"
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hvals h_uid
1. "Falcon.C"
2. "NetSeek"
3. "LinuxTone"
4. "linuxtone.org"
5. "qq.com"
复制代码
表示批量设置hash字段的值
 
HINCRBY操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hincrby h_uid_incr uid 1
(integer) 1
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hincrby h_uid_incr uid 1
(integer) 2
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hincrby h_uid_incr uid 3
(integer) 5
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hvals h_uid_incr
1. "5"
复制代码
表示对指定的hash字段的值进行递增操作
 
HEXISTS操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hexists h_uid uid001
(integer) 1
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hexists h_uid uid0011
(integer) 0
复制代码
表示判断指定的hash字段是否存在
 
HDEL操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hset h_uid uid 1
(integer) 1
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hvals h_uid     
1. "Falcon.C"
2. "NetSeek"
3. "LinuxTone"
4. "linuxtone.org"
5. "qq.com"
6. "1"
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hdel h_uid uid
(integer) 1
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hvals h_uid   
1. "Falcon.C"
2. "NetSeek"
3. "LinuxTone"
4. "linuxtone.org"
5. "qq.com"
复制代码
表示通过指定的hash字段删除hash值
 
HLEN操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hlen h_uid
(integer) 5
复制代码
表示返回hash长度
 
LKEYS操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hkeys h_uid
1. "uid001"
2. "uid002"
3. "uid003"
4. "uid004"
5. "uid005"
复制代码
表示返回指定hash的所有key
 
HVALS操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hvals h_uid
1. "Falcon.C"
2. "NetSeek"
3. "LinuxTone"
4. "linuxtone.org"
5. "qq.com"
复制代码
表示返回指定hash的所有value
 
HGETALL操作
[falcon@www.fwphp.cn  ~/redis-2.0.0]$ ./redis-cli hgetall h_uid
1. "uid001"
2. "Falcon.C"
3. "uid002"
4. "NetSeek"
5. "uid003"
6. "LinuxTone"
7. "uid004"
8. "linuxtone.org"
9. "uid005"
10. "qq.com"
复制代码
表示返回指定hash的所有字段及关联的值
 
 
公共操作命令部分:(不受数据类型的影响)
Command         Parameters         Description 
SORT            key BY pattern LIMIT start end GET pattern ASC|DESC ALPHA Sort a 
Set or a List accordingly to the specified parameters
数据持久化控制命令
SAVE             -                 Synchronously save the DB on disk
BGSAVE             -                 Asynchronously save the DB on disk 
LASTSAVE         -                 Return the UNIX time stamp of the last successfully saving 
          of the dataset on disk 
SHUTDOWN         -                 Synchronously save the DB on disk, then shutdown the 
          server 
BGREWRITEAOF     -                 Rewrite the append only file in background when it gets 
          too big
 
远程服务器控制命令
INFO            -                 Provide information and statistics about the server 
MONITOR         -                 Dump all the received requests in real time 
SLAVEOF         -                 Change the replication settings 
CONFIG             -                 Configure a Redis server at runtime 
 
 
以下转自 http://www.madcn.net/?p=693
连接控制
QUIT 关闭连接
AUTH (仅限启用时)简单的密码验证
 
适合全体类型的命令
EXISTS key 判断一个键是否存在;存在返回 1;否则返回0;
DEL key 删除某个key,或是一系列key;DEL key1 key2 key3 key4
TYPE key 返回某个key元素的数据类型 ( none:不存在,string:字符,list,set,zset,hash)
KEYS pattern 返回匹配的key列表 (KEYS foo*:查找foo开头的keys)
RANDOMKEY 随机获得一个已经存在的key,如果当前数据库为空,则返回空字符串
RENAME oldname newname更改key的名字,新键如果存在将被覆盖
RENAMENX oldname newname 更改key的名字,如果名字存在则更改失败
DBSIZE返回当前数据库的key的总数
EXPIRE设置某个key的过期时间(秒),(EXPIRE bruce 1000:设置bruce这个key1000秒后系统自动删除)注意:如果在还没有过期的时候,对值进行了改变,那么那个值会被清除。
TTL查找某个key还有多长时间过期,返回时间秒
SELECT index 选择数据库
MOVE key dbindex 将指定键从当前数据库移到目标数据库 dbindex。成功返回 1;否则返回0(源数据库不存在key或目标数据库已存在同名key);
FLUSHDB 清空当前数据库中的所有键
FLUSHALL 清空所有数据库中的所有键
 
 
处理字符串的命令
SET key value 给一个键设置字符串值。SET keyname datalength data (SET bruce 10 paitoubing:保存key为burce,字符串长度为10的一个字符串paitoubing到数据库),data最大不可超过1G。
GET key获取某个key 的value值。如key不存在,则返回字符串"nil";如key的值不为字符串类型,则返回一个错误。
GETSET key value可以理解成获得的key的值然后SET这个值,更加方便的操作 (SET bruce 10 paitoubing,这个时候需要修改bruce变成1234567890并获取这个以前的数据paitoubing,GETSET bruce 10 1234567890)
MGET key1 key2 … keyN 一次性返回多个键的值
SETNX key value SETNX与SET的区别是SET可以创建与更新key的value,而SETNX是如果key不存在,则创建key与value数据
MSET key1 value1 key2 value2 … keyN valueN 在一次原子操作下一次性设置多个键和值
MSETNX key1 value1 key2 value2 … keyN valueN 在一次原子操作下一次性设置多个键和值(目标键不存在情况下,如果有一个以上的key已存在,则失败)
INCR key 自增键值
INCRBY key integer 令键值自增指定数值
DECR key 自减键值
DECRBY key integer 令键值自减指定数值
 
处理 lists 的命令
RPUSH key value 从 List 尾部添加一个元素(如序列不存在,则先创建,如已存在同名Key而非序列,则返回错误)
LPUSH key value 从 List 头部添加一个元素
LLEN key 返回一个 List 的长度
LRANGE key start end从自定的范围内返回序列的元素 (LRANGE testlist 0 2;返回序列testlist前0 1 2元素)
LTRIM key start end修剪某个范围之外的数据 (LTRIM testlist 0 2;保留0 1 2元素,其余的删除)
LINDEX key index返回某个位置的序列值(LINDEX testlist 0;返回序列testlist位置为0的元素)
LSET key index value更新某个位置元素的值
LREM key count value 从 List 的头部(count正数)或尾部(count负数)删除一定数量(count)匹配value的元素,返回删除的元素数量。
LPOP key 弹出 List 的第一个元素
RPOP key 弹出 List 的最后一个元素
RPOPLPUSH srckey dstkey 弹出 _srckey_ 中最后一个元素并将其压入 _dstkey_头部,key不存在或序列为空则返回"nil"
 
处理集合(sets)的命令(有索引无序序列)
SADD key member增加元素到SETS序列,如果元素(membe)不存在则添加成功 1,否则失败 0;(SADD testlist 3 \n one)
SREM key member 删除SETS序列的某个元素,如果元素不存在则失败0,否则成功 1(SREM testlist 3 \N one)
SPOP key 从集合中随机弹出一个成员
SMOVE srckey dstkey member 把一个SETS序列的某个元素移动到另外一个SETS序列 (SMOVE testlist test 3\n two;从序列testlist移动元素two到 test中,testlist中将不存在two元素)
SCARD key 统计某个SETS的序列的元素数量
SISMEMBER key member 获知指定成员是否存在于集合中
SINTER key1 key2 … keyN 返回 key1, key2, …, keyN 中的交集
SINTERSTORE dstkey key1 key2 … keyN 将 key1, key2, …, keyN 中的交集存入 dstkey
SUNION key1 key2 … keyN 返回 key1, key2, …, keyN 的并集
SUNIONSTORE dstkey key1 key2 … keyN 将 key1, key2, …, keyN 的并集存入 dstkey
SDIFF key1 key2 … keyN 依据 key2, …, keyN 求 key1 的差集。官方例子:
key1 = x,a,b,c
key2 = c
key3 = a,d
SDIFF key1,key2,key3 => x,b
SDIFFSTORE dstkey key1 key2 … keyN 依据 key2, …, keyN 求 key1 的差集并存入 dstkey
SMEMBERS key 返回某个序列的所有元素
SRANDMEMBER key 随机返回某个序列的元素
 
处理有序集合(sorted sets)的命令 (zsets)
ZADD key score member 添加指定成员到有序集合中,如果目标存在则更新score(分值,排序用)
ZREM key member 从有序集合删除指定成员
ZINCRBY key increment member 如果成员存在则将其增加_increment_,否则将设置一个score为_increment_的成员
ZRANGE key start end 返回升序排序后的指定范围的成员
ZREVRANGE key start end 返回降序排序后的指定范围的成员
ZRANGEBYSCORE key min max 返回所有符合score >= min和score <= max的成员 ZCARD key 返回有序集合的元素数量 ZSCORE key element 返回指定成员的SCORE值 ZREMRANGEBYSCORE key min max 删除符合 score >= min 和 score <= max 条件的所有成员
 
排序(List, Set, Sorted Set)
SORT key BY pattern LIMIT start end GET pattern ASC|DESC ALPHA 按照指定模式排序集合或List
 
SORT mylist
默认升序 ASC
 
SORT mylist DESC
 
SORT mylist LIMIT 0 10
从序号0开始,取10条
 
SORT mylist LIMIT 0 10 ALPHA DESC
按首字符排序
 
SORT mylist BY weight_*
SORT mylist BY weight_* GET object_*
SORT mylist BY weight_* GET object_* GET #
 
SORT mylist BY weight_* STORE resultkey
将返回的结果存放于resultkey序列(List)
 
持久控制
SAVE 同步保存数据到磁盘
BGSAVE 异步保存数据到磁盘
LASTSAVE 返回上次成功保存到磁盘的Unix时间戳
SHUTDOWN 同步保存到服务器并关闭 Redis 服务器(SAVE+QUIT)
BGREWRITEAOF 当日志文件过长时重写日志文件
 
远程控制命令
INFO 提供服务器的信息和统计信息
MONITOR 实时输出所有收到的请求
SLAVEOF 修改复制选项
 
redis目前提供四种数据类型:string,list,set及zset(sorted set)。
* string是最简单的类型,你可以理解成与Memcached一模一个的类型,一个key对应一个value,其上支持的操作与Memcached的操作类似。但它的功能更丰富。
* list是一个链表结构,主要功能是push、pop、获取一个范围的所有值等等。操作中key理解为链表的名字。
* set是集合,和我们数学中的集合概念相似,对集合的操作有添加删除元素,有对多个集合求交并差等操作。操作中key理解为集合的名字。
* zset是set的一个升级版本,他在set的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新的值调整顺序。可以理解了有两列的mysql表,一列存value,一列存顺序。操作中key理解为zset的名字。
 
协议
redis目前只有基于TCP的文本协议,与memcache类似,有一些改进。
客户端通常发送
命令 参数… 值字节数\r\n
值\r\n
 
服务端的返回,根据第一个字节,可以判断:
- 错误信息
+ 普通文本信息
$ 变长字节数,$6表示CRLF之后有6个字节的字符
: 返回一个整数
* 返回组数,即*6表示CRLF之后将返回6组变长字符
 
注意事项:
Key不可包含空格或者回车符
Key不要过长或过短,应使其有意义,如"comment:1234:reply.to"

redis Ok2的更多相关文章

  1. 探索Redis设计与实现14:Redis事务浅析与ACID特性介绍

    本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...

  2. Redis入门和Java利用jedis操作redis

    Redis入门和Java利用jedis操作redis Redis介绍 Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库. Redis 与其他 key - val ...

  3. 使用redis构建可靠分布式锁

    关于分布式锁的概念,具体实现方式,直接参阅下面两个帖子,这里就不多介绍了. 分布式锁的多种实现方式 分布式锁总结 对于分布式锁的几种实现方式的优劣,这里再列举下 1. 数据库实现方式 优点:易理解 缺 ...

  4. Ignite性能测试以及对redis的对比

    测试方法 为了对Ignite做一个基本了解,做了一个性能测试,测试方法也比较简单主要是针对client模式,因为这种方法和使用redis的方式特别像.测试方法很简单主要是下面几点: 不作参数优化,默认 ...

  5. mac osx 安装redis扩展

    1 php -v查看php版本 2 brew search php|grep redis 搜索对应的redis   ps:如果没有brew 就根据http://brew.sh安装 3 brew ins ...

  6. Redis/HBase/Tair比较

    KV系统对比表 对比维度 Redis Redis Cluster Medis Hbase Tair 访问模式    支持Value大小 理论上不超过1GB(建议不超过1MB) 理论上可配置(默认配置1 ...

  7. Redis数据库

    Redis是k-v型数据库的典范,设计思想及数据结构实现都值得学习. 1.数据类型 value支持五种数据类型:1.字符串(strings)2.字符串列表(lists)3.字符串集合(sets)4.有 ...

  8. redis 学习笔记(2)

    redis-cluster 简介 redis-cluster是一个分布式.容错的redis实现,redis-cluster通过将各个单独的redis实例通过特定的协议连接到一起实现了分布式.集群化的目 ...

  9. redis 学习笔记(1)

    redis持久化 snapshot数据快照(rdb) 这是一种定时将redis内存中的数据写入磁盘文件的一种方案,这样保留这一时刻redis中的数据镜像,用于意外回滚.redis的snapshot的格 ...

随机推荐

  1. ORA-12705: Cannot access NLS data files or invalid environment specified

    ASM实例无法启动 [grid@data ~]$ sqlplus / as sysasm SQL*Plus: Release 11.2.0.4.0 Production on Fri Sep 11 0 ...

  2. 自我总结(五)---(学习j2ee)

    自我完善的过程就是在不断的自我总结不断的改进. 我们这半个月来都是学习j2ee.这个知识是很重要的,一般我们出去工作都是会用到的.我们的星期六,星期天也是不上课的.所以说我相当于上了十天的j2ee了. ...

  3. word双栏排版,最后一页由于分节符造成最后一页是空白页,删除分节符双栏就变成了单栏

    遇到这个问题时,我们把心思都花在了如何“删除”这个空白页. 但是最有效的办法不是“删除”,而是(以word2007为例): Word 2007中文版: 鼠标放在最后一页,点击页面布局①,选择页面布局右 ...

  4. Java JTable 表格 获取存储路径,文件名 ,导出excel表格

    在做计量泵上位机软件时,需要将下位机传上来的数据,存入MYSQL数据库,显示在java 上位机界面上,并能导出至电脑指定位置. 选择存储路径和文件名: // 处理另存文件的菜单 public void ...

  5. karma+angular

    下面的介绍以karma能正常运行为前提,看karma系列文章:http://www.cnblogs.com/laixiangran/tag/Karma/ 目录结构 步骤 安装 npm install ...

  6. SAP MM模块之批次管理

    1.Batch的定义:Batch is a quantity any drug produced during a given cycle of manufacture. The essence of ...

  7. 【Unity Shaders】初探Surface Shader背后的机制

    转载请注明出处:http://blog.csdn.net/candycat1992/article/details/39994049 写在前面 一直以来,Unity Surface Shader背后的 ...

  8. MHA的几种死法-叶良辰

    master不通      找到最新slave           找到有所有其他slave缺失relay log的 slave      选主           配置文件指定           ...

  9. Android Snackbar

    使用Snackbar我们可以在屏幕底部(大多时候)快速弹出消息,它和Toast非常相似,但是它更灵活一些. 当它显示一段时间后或用户与屏幕交互时它会自动消失. 可以自定义action-可选操作. sw ...

  10. GIT命令(急速学习)

    用过sourceTree,egit(eclipse中的git插件),最后还是感觉git bash顺手:svn早已经不用:   先上几个原来看过的git 教程--书读百遍,其义自见.多看几篇文章才能总结 ...