管理员
论坛积分
分
威望 点
贡献值 个
金币 枚
|
- **php.ini文件添加:extension=php_redis.dll 重启php, phpinfo可以看到redis则证明安装成功**
复制代码 php连接redis测试- <?php
. x0 T% L, q4 H6 J - $redis = new Redis();
% t8 W5 ~& [7 ^) Z+ Y* A - $redis->connect('127.0.0.1', 6379);//serverip port9 g3 I" O( x/ n5 w3 Q- S
- $redis->auth('mypassword');//my redis password
5 U c. n3 K7 g6 e1 R - $redis ->set( "test" , "Hello World");
1 ?9 m! h( Q5 p* f! A5 e D - echo $redis ->get( "test");
: |$ Q C( x3 {) @$ c9 q. v
复制代码 php操作redis函数封装- /**
& N+ U; e! y, H" y( Z( Z - * 如果不传入$host和$port默认读取Laravel环境变量的参数% l8 S4 ^- e6 b+ a5 m
- * redis Set/setex封装,可直接传入数组,可设置过期时间 written:yangxingyi
! [) x% \/ T* e, M - */; b( s* i# v4 ^& O) w5 F' J
- function RedisSet($key,$value,$expire=0,$host='',$port=''){. s Y8 I: g3 y4 S: f1 d# o
- if(!$key||!$value) return false;. P9 S+ I) H6 P' Y6 S# O
- $host = $host?$host:getenv('REDIS_HOST');, }) L* p/ \7 z
- $port = $port?$port:getenv('REDIS_PORT');
8 Z2 p0 J5 g) _ - $redis = new Redis();7 J# S- F2 j& y* y% A
- $redis->connect($host, $port);
% X6 j8 F! i5 d$ @' z - $value = is_array($value)?json_encode($value):$value;& s$ l3 l0 c' i) o7 g1 I
- return $expire>0?$redis->setex(getenv('REDIS_PREFIX').$key, $expire,$value):$redis->set(getenv('REDIS_PREFIX').$key,$value); y( |9 C, G% W
- }
" ^9 _) v& o3 y8 z0 o - /**; z$ ?! K. _3 ?- l; I/ q
- * redis get封装,如果传入的是数组,返回的也是数组,同理字符串 written:yangxingyi
" C( ]3 d6 K& q4 }( Y- K' D - */
, B3 _* f) r' f - function RedisGet($key,$host='',$port=''){
6 y- J6 s% p9 c- u0 O - $redis = new Redis();% D: R( q# E8 [' P7 f4 @
- $host = $host?$host:getenv('REDIS_HOST');
% @( B" ?# }- I1 y - $port = $port?$port:getenv('REDIS_PORT');8 o5 G0 f5 c2 m0 d& }
- $redis->connect($host, $port);
& @9 c j, l$ U! B b3 B - $result = $redis->get(getenv('REDIS_PREFIX').$key);
+ B' n/ ?5 f6 d. m x - return is_null(json_decode($result))?$result:json_decode($result,true);
0 S$ ]# x' H1 B0 T" ? - }
% p ?2 b9 Y2 H' q. U+ d
复制代码 php操作redis大全,基本上php操作redis常用的函数都在下面了: m) l& @8 W% f1 u1 y
- setex 带生存时间的写入值 c" N7 r* T$ M$ N, F
- $redis->setex('key', 3600, 'value'); 5 A2 A8 N1 F) z* `) `
- setnx 判断是否重复的,写入值,如存在了不修改返回0,不存在就添加返回1
5 `! Y2 A! u# k - $redis->setnx('key', 'value');
- r8 @! F E1 x- \ - 返回已经删除key2 p6 \8 w! i8 K7 g" ~
- $redis->delete('key1'); 成功返回1失败返回0* f% m+ S' ?5 D+ }& Y
- $redis->delete('key1','key2'); 删除两个键成功返回1失败返回00 Y5 x6 r4 l+ G5 u
- 查询生存时间
7 f1 n$ n* k) [1 E& O - $redis->ttl('key1'); 持久化的返回-1,有生存时间的返回时间(单位秒)
7 @5 L4 y% I8 W. e. v; S" _% _ - 同时给多个key赋值,同时设置key0和key15 N. o3 E# u n2 s/ X2 N' d
- $redis->mset(array('key0' => 'value0', 'key1' => 'value1'));
, b- L, Y& P/ U7 n( z - key中的值进行自增1,如果填写了第二个参数,者自增第二个参数所填的值; i% ~, a. p! S% f m
- $redis->incr('key1');0 ?! t6 o$ d1 Z/ x0 t
- $redis->incrBy('key1', 10);
' Q' K) u5 n7 n' e4 C - 减法跟加法一样
0 I, X/ `$ Y& ?. N& K- u$ s4 ^: ~ - $redis->decr("key1"); 减少1
k' ]* }0 n a9 c5 J8 S- D - $redis->decrBy("key1",5) 减少5$ R! T {$ I$ l* f+ F) n; b6 P: o
- 0 q" [8 \$ y+ ^+ D
- list相关操作,连表操作
# R% q; f* ]) M& d) u" } - lPush
' q( w8 T5 f' i" E/ s/ e4 U: |. | - $redis->lPush("list", "888");0 V3 g/ x' Y8 Q( |
- $id = $redis->lpush('list','HHHHHHH');echo $id;返回链表的元素个数2 s9 g$ O9 n) H) r5 F
- $redi->lrange('list',0,-1); 返回全部数据,数组形式
# `1 J) o: ~' U8 u( y( ]! v& ] - $redis->lrange('list',0.2); 返回连表0-2坐标的三个元素
& X3 h8 c( p: x) F& s - lPushx/rPushx
/ @. n/ P0 d' r, w; L) i - $redis->lPushx(key, value);
9 h0 y! T" a$ u: x/ o7 }8 @9 J - 在名称为key的list左边(头)/右边(尾)添加一个值为value的元素,如果value已经存在,则不添加& x1 U' O6 I9 ^( k
- ! u) _( r7 p5 H
- $redis->lpop('list');输出链表最左边的ksy的值,输出后删除掉这个key
5 k5 d; u; r8 B( {( o# k - $redis->rpop('list');输出链表最右边的ksy的值,输出后删除掉这个key
2 T1 S8 [" ^* v - $redis->lset('list',7,"update"); 修改坐标为7的值,成功返回1
, E" a2 b% p; H- _" K6 ^, g4 L# O - 集合:sadd,sadd是无序的集合,每次插入集合的时候都可能会弄乱里面集合的排序! `. P3 g0 b1 D+ {& _8 L+ J
- sadd s1 zhangsan
* Z( u; I. n- I7 P+ I1 { - sadd s1 lisi, v6 `( X. ?( S& |& n
- sadd s1 wangwu
3 _3 T+ _2 R% z- O P - sadd t1 yangxingyi5 Y r8 m4 _: i9 {8 h- Y% a
- sadd t1 lilei( U/ u' ~& M/ Y, G3 G; d
- sadd t1 zhangsan# P! G j: E; f1 R, e, R5 m* C" a+ R
- smembers s1 s1的所有集合内容( O% V! y: a' e, I
- sdiff s1 t1 s1有的,t1没有的,差集
( X8 f% S- T0 D/ v; O - $redis->sinter('s1','t1');返回s1和t1两个集合都有的,数组形式' e/ F/ M0 R/ K8 W7 V/ `
- scard s1 返回s1集合里面的个数,有多少个就返回多少个,没有从0开始的,坐标才从0开始的1 q6 u1 B- v" U$ a
- spop抽奖场景,返回集合里面随机的数3 A# u) i# ?) W \3 E$ C& T
- spop s1 默认返回1个,返回后就删除这个数,中奖了就不能再中了
2 H/ r0 w' X' ]$ }. g c - $i = $redis->spop('s1');var_dump($i); 返回一个数,返回后删除这个数
9 t4 |% h* |* \ - $i = $redis->spop('s1',2);var_dump($i);不能返回两个的,提示错误的
8 A9 V4 c5 d$ E5 }& u& Y3 ] - 随机返回集合里面的一个元素,但不删除,重复中奖 y H3 e* z) G
- $i = $redis->srandmember('s1');echo $i;/ e, t' p3 g' U8 e( B8 q r
- sismember s1 zhangsan 查询张三在不在集合里面,在1,不在false
# u4 f j9 p1 f% v0 H - $i = $redis->sismember('s1','zhangsan2');echo $i;在1,不在false
3 N+ \( ~4 I v' W+ N7 J7 K4 ] - B( B- l: J) M5 @7 E9 g4 ~4 z7 a
- zadd key 2 value 有序集合
" Q* F0 z* e, b8 l4 ]* \$ c% ^1 c - zadd y1 1 zhangsan;
$ d7 U3 G& A+ ~/ `; a, M - zadd y1 3 lisi;5 S! o7 Y/ M) e0 ?
- zadd y1 2 wangwu;- ^- @6 R9 I4 E: E% f0 T
- zrange y1 0 -1; 排序就是,根据插入的时候的排序从小到达zhangsan,wangwu,lisi
# ^. M. @( ]' l - $i = $redis->zrange('y1',0,-1);var_dump($i);6 b9 m' f" m* Q" A+ M, c
- 返回数组,键值不是插入时候给的键,是从0开始的新键
5 _5 [; n/ H0 I$ O/ O% V - zrevrange y1 0 -1; 反转排序,插入的时候键值越高,排序越优先
q( |, l1 S$ ` k - zcard y1 ;获取有序集合里面的个数,有多少个就返回多少个,没有从0开始的,坐标才从0开始的% \( [! b! w- N" t5 o, `7 H/ h! d
- 无序就scard,有序就zcard,有z没有s
7 X8 Z$ I8 N% L: C - sInterStore( W1 w" R2 V& @) n
- 求交集并将交集保存到output的集合
$ a ]6 g- p! v, n7 J/ e - $redis->sInterStore('output', 'key1', 'key2', 'key3')
, a% }2 N: f' D$ m8 _ -
. E' M/ D3 g8 z. |0 n$ a - Hash操作0 W7 R$ F! x) ] n4 n/ B" z2 Q
- hSet
- N. V+ b9 `7 L* X* a - $redis->hSet('h', 'key1', 'hello');
( c5 t4 W/ H& { - 向名称为h的hash中添加元素key1—>hello/ z- K) M1 m: E, ]) w3 |
/ i. A/ u+ h* T- hGet
! b: N/ v, X+ l2 x& V ] - $redis->hGet('h', 'key1');3 p5 f; v. f. s$ Y: e4 ~
- 返回名称为h的hash中key1对应的value(hello)
# h: j! E3 t! X: g* g/ U" I. T - 5 P% l# x. t% U) X7 |
- hLen+ F+ j; i& u* u$ L. J0 v
- $redis->hLen('h');* J O# R' A3 B/ D8 e, [' M0 n% |
- 返回名称为h的hash中元素个数6 @. ~4 r8 S5 y
- 3 ]5 Q. h3 {, u, J- C% w! d
- hDel9 _" o9 a( w) y6 L; A4 r
- $redis->hDel('h', 'key1');9 h2 _7 n- K/ I6 V6 i5 H0 R. M
- 删除名称为h的hash中键为key1的域5 M1 J7 L9 y: {
- 2 z! X" {& \, E5 C% v7 _) n
- hKeys
3 T; r% X' W. p( c: E - $redis->hKeys('h');
) x, o [0 P$ ^4 v# b; ^. u - 返回名称为key的hash中所有键
8 w# P+ e$ T6 _/ r0 z& S7 ` - ' C$ a) V. l- Y% S) P
- hVals
" B5 u! O" a7 r$ C# K! n - $redis->hVals('h')
' b" [. s7 V0 ~* O: N1 Z( v - 返回名称为h的hash中所有键对应的value
# j! i' {; B, z8 M - 4 O4 e& m' i% c# C2 k/ _, `
- hGetAll
/ j* z# P$ k3 E8 P; l' n& R; P - $redis->hGetAll('h');
+ l; v' h7 n" X5 [4 C - 返回名称为h的hash中所有的键(field)及其对应的value4 P) v2 C) A8 \+ B: i# c- V
8 b( A' A+ T2 T! z- hExists# o9 f; O7 |8 s3 M
- $redis->hExists('h', 'a');
# a. r+ T# A! }3 E7 w7 b2 q" \0 f5 } - 名称为h的hash中是否存在键名字为a的域% ]1 z2 P, e' Q3 i
0 J) j( C( _, Y' A2 d9 N- hIncrBy. l. N' g2 Z8 D
- $redis->hIncrBy('h', 'x', 2);$ Y8 p' @$ S3 O3 d( j, T
- 将名称为h的hash中x的value增加2
1 o& j6 }% }0 p1 G
3 r+ s3 {6 S5 i8 t- s9 w- hMset
9 C6 H% u! W- W* ~+ I3 p - $redis->hMset('user:1', array('name' => 'Joe', 'salary' => 2000));
, {* C5 [* S5 |# A7 Y' @9 Y$ k - 向名称为key的hash中批量添加元素
& h: ]1 Q g. {0 m F q6 \ - ( X% \/ S K5 p! c- Z- n) l; e
- hMGet* ] D: i+ d; }" e z4 s/ |: N* `+ [- c- M
- $redis->hmGet('h', array('field1', 'field2'));& E- g3 n1 V" D4 f: j
- 返回名称为h的hash中field1,field2对应的value
. w1 V1 ]# S z! N S - 2 s( m2 f% B+ B' F4 o
- redis 操作相关0 r! _3 X' p5 V3 S
- flushDB4 G: @; T8 r4 L3 d
- 清空当前数据库7 {+ X ?& [: J5 [
- * A G0 |6 t: F% C7 E
- flushAll
. D9 C/ I; _. |& Q3 E( T8 g - 清空所有数据库/ g7 O' {4 p. ^4 F% k" O
0 H3 f6 e" R3 T( W) _" n/ C0 i% c B- randomKey x$ j) e9 H3 N% k, F2 a
- 随机返回key空间的一个key
4 I7 \8 N0 G" {: k2 Q - $key = $redis->randomKey();! {- g: @6 W3 a6 u8 G. i1 R% X
9 ?% n$ ?! i# f( ?8 I$ {- select% n" H+ \5 `3 H) V
- 选择一个数据库$ a% f$ W, ^; j8 R1 S: ?
- move3 F- ?/ H) E8 V
- 转移一个key到另外一个数据库
# E F" L$ p* M3 Q. T; B) B8 m - $redis->select(0); // switch to DB 03 K* O' W& f8 {
- $redis->set('x', '42'); // write 42 to x
: u$ w4 S3 e8 d6 ^+ e: B. g! B - $redis->move('x', 1); // move to DB 11 V Z- v6 o! o! Z& E) [
- $redis->select(1); // switch to DB 1' U( g) p2 G6 v2 J8 L. k/ Y: g$ M
- $redis->get('x'); // will return 42% _7 Q: S H0 l* P$ M
, k, J9 W2 p' v# y! H8 r, O- rename, renameKey$ K( l: s, O D+ s' D, z! N+ @
- 给key重命名
& O& k( s4 ~+ Q* X/ J - $redis->set('x', '42');1 e6 `0 G# ^0 P8 A/ G1 e# T8 ?
- $redis->rename('x', 'y');
6 o: u( l4 `2 }( Z0 B6 S2 G - $redis->get('y'); // → 42
1 ]" [8 a( Q2 @" G3 A - $redis->get('x'); // → `FALSE`
" S8 I, f3 V6 z/ S - % b, a! T% R r7 u0 H! m
- renameNx/ b8 E0 S8 z! v ~
- 与remane类似,但是,如果重新命名的名字已经存在,不会替换成功8 }* R% ?7 T: G& ^
$ f# ]- } u' Y4 ^6 i8 M- setTimeout, expire
9 x i" j3 w* o0 v( W - 设定一个key的活动时间(s)2 A2 S; ~2 `/ b
- $redis->setTimeout('x', 3);
% D. p0 c" i2 g" B - ( I5 F) C! J8 T m/ E3 [* i
- expireAt
7 _' M* N, [9 A6 } - key存活到一个unix时间戳时间8 i7 F( r+ F( U
- $redis->expireAt('x', time() + 3);. M6 m* v9 N; m9 Y
" W3 K O- T: T/ r; k- keys, getKeys% S( W& q3 V3 K8 L( r
- 返回满足给定pattern的所有key
" J) H# o* N& Z2 O6 L - $keyWithUserPrefix = $redis->keys('user*');
1 z2 D; S6 e4 }; K% Z& q2 M; n - / }4 W, Q( P) l7 _9 Q* J, \# ?0 ?' u
- dbSize
: r6 B8 Z* r+ i. ]: `9 C - 查看现在数据库有多少key
. l" U2 u' T3 m. b- s - $count = $redis->dbSize();
# G9 `' l1 N' _( _9 N9 r
" {) y% H) c' e/ G- auth8 O5 B$ S k3 O3 K# \
- 密码认证& j" o* ?1 s2 L
- $redis->auth('foobared');& @, z9 K `8 d3 q" b n' [
- - P$ h% s' Q |# _9 X v& c5 o
- bgrewriteaof
3 R5 L) I: `) }3 c8 H+ h; y9 m - 使用aof来进行数据库持久化
, R3 X& v+ T6 W. _! ?3 \ - $redis->bgrewriteaof();
6 `9 s k a( r) P+ u7 H1 h0 d - 4 r, J" C8 s- s' H' `
- slaveof: m5 o/ H) M* t" }3 h
- 选择从服务器
& g5 z4 B4 K: p6 J2 f - $redis->slaveof('10.0.1.7', 6379);
* \7 ^! p0 D' o% i" M; M/ B& J. L N
. ~9 f7 ]4 Z h( e0 O4 H7 E- save
+ n0 ]9 a+ Y. N7 ^2 j' t0 S5 A - 将数据同步保存到磁盘
7 e. x* P8 P& r% o& h9 z
' S3 n6 L5 w# n2 n# x: ?' G# ]7 ]- bgsave
, l9 h t, j T) W - 将数据异步保存到磁盘
1 y# I F- E) w9 d
7 E i' u4 P0 _; T/ U$ o- lastSave
% e2 ~! D/ d0 |# q8 S; } - 返回上次成功将数据保存到磁盘的Unix时戳8 q2 \7 h9 J0 f$ j+ }& b) t
1 Y( O+ Z5 R0 v1 F, p9 n- info
) E. T$ H, ^# F1 |; `- m - 返回redis的版本信息等详情( j" j/ V7 z* ?8 V* _6 F
# L! ^+ D# A K! o/ [+ C- Redis::__construct构造函数: p1 `% ?! m( y- _
- $redis = new Redis();) u9 W3 E; _/ N0 J' N
" f$ E5 O) y8 F6 u! V- connect, open 链接redis服务
7 F% l. a9 |/ w - 参数8 ^! {% C( Y3 L: }
- host: string,服务地址; h+ p* u- Q$ ]* C2 z: \
- port: int,端口号2 ?' Z8 p3 w! X: M
- timeout: float,链接时长 (可选, 默认为 0 ,不限链接时间), s. i! u7 ]0 [
- 注: 在redis.conf中也有时间,默认为300# q, U2 q; f+ y! [, G
- ' c9 G- H) y! p4 _/ J% K
- pconnect, popen 不会主动关闭的链接
- m, N, q. A$ ^+ I* a - 参考上面4 ~- M5 T1 V5 |2 H3 P6 U+ ^4 V4 j
- ) [' C! \: K5 P7 ~
- setOption 设置redis模式+ I4 o6 R7 G7 i4 Z
- 4 o# {' w8 ~. x' A, P/ T
- getOption 查看redis设置的模式
! \( d: [/ u2 A' E# _ j
& U6 }. b# M8 t- ping 查看连接状态
5 Q3 X+ U3 ~: S" `* t7 Y
5 |; r$ p! v2 k* I) v" Q" @" {- get 得到某个key的值(string值)) t. ~" C1 F! s+ S G n
- 如果该key不存在,return false& b, f6 K; z# I* }8 k" [3 X
- $ j* |0 |' r5 z6 J7 o7 `
- set 写入key 和 value(string值)
8 X+ ~4 G& V( k- q - 如果写入成功,return ture, M7 V) n+ m l4 W
4 g! q. f* X+ O# L0 I- R- setex 带生存时间的写入值6 p+ p/ K4 Y% U: v
- $redis->setex('key', 3600, 'value'); // sets key → value, with 1h TTL.
* u" a. ^, e0 q
' t5 ?! x7 K. e' d5 C( y- setnx 判断是否重复的,写入值0 O3 A0 Q: l1 v8 {( [/ J
- $redis->setnx('key', 'value');" ]9 Y; U2 |1 N; ~
- $redis->setnx('key', 'value'); F) y* u+ R+ p: t- I3 h
7 q9 h# K5 o1 }& x- delete 删除指定key的值* K' n! g" e4 ]$ ` `/ K9 a
- 返回已经删除key的个数(长整数)+ }+ n, w* c. C' B) u8 k
- $redis->delete('key1', 'key2');
( f. B$ v3 ? R& ~. B - $redis->delete(array('key3', 'key4', 'key5'));! A2 R& O. l( @# {- t
- " L! Z. K. e5 [1 T7 p, G- N9 b: `
- ttl( u$ N$ f! k! \$ x b( a( E
- 得到一个key的生存时间
. m8 b7 i" Y2 k, r6 @$ V) x
- _4 q' B+ f0 r- persist
( W5 o( T0 k4 x( G1 m( | - 移除生存时间到期的key
4 E k% I- K# k( G5 T7 v* n - 如果key到期 true 如果不到期 false8 J+ f& \$ J3 B. C2 Z- @6 |
- 4 Z( d0 }) Y# q, v, [
- mset (redis版本1.1以上才可以用), S# [* Q' k3 d' P7 m. u3 b2 `
- 同时给多个key赋值) p: N! V! J" e7 \2 R
- $redis->mset(array('key0' => 'value0', 'key1' => 'value1'));4 H/ |4 R, P8 [! ~3 s: C' _9 |
( P, H. l3 U; [- . ]" J% x% g6 l* f8 V" N* k& |
" |# w" @" }( h; `) q. v9 a- multi, exec, discard3 w' C9 Y" B8 g) g0 _% Y
- 进入或者退出事务模式, p' k6 f" i$ U9 j
- 参数可选Redis::MULTI或Redis::PIPELINE. 默认是 Redis::MULTI7 d8 M% Z; {# P; S- o
- Redis::MULTI:将多个操作当成一个事务执行
2 v8 o& ]+ V7 |: R; c - Redis::PIPELINE:让(多条)执行命令简单的,更加快速的发送给服务器,但是没有任何原子性的保证
' Y2 W# B; I. w- U- S - discard:删除一个事务
& X* {5 {% R- F: z# |, i4 Y7 W - 返回值9 Q9 l" T" Q- w0 J; d7 d* B
- multi(),返回一个redis对象,并进入multi-mode模式,一旦进入multi-mode模式,以后调用的所有方法都会返回相同的对象,只到exec()方法被调用。% [8 `/ R( S+ N0 X% J
- u9 P. \* w# R* H
- watch, unwatch (代码测试后,不能达到所说的效果)
2 u9 x1 n1 c+ P6 _' b - 监测一个key的值是否被其它的程序更改。如果这个key在watch 和 exec (方法)间被修改,这个 MULTI/EXEC 事务的执行将失败(return false)8 Z1 Y& ^/ h' z0 l
- unwatch 取消被这个程序监测的所有key( K! Q5 ?5 ]& p) f" E
- 参数,一对key的列表
% l: r" Y! A* C( h" S - $redis->watch('x');
. Q8 D% l R9 F5 o
6 y0 B# q# Z) O5 y: I: _& ^% a6 T4 C' n7 o- $ret = $redis->multi() ->incr('x') ->exec();
" S8 `& T+ j, ?2 c, T - $ _" O- ?# e. }
- . r5 D! C8 p: {7 v2 s. A
- subscribe *
% O0 m) x* d4 | - 方法回调。注意,该方法可能在未来里发生改变
1 F$ R. w; U0 Y - ' J3 O0 X+ M" e1 ] J8 p
- publish *4 f$ I5 V% b3 k2 U
- 发表内容到某一个通道。注意,该方法可能在未来里发生改变7 Z- F" P; {- U) B- D
- & [9 Y4 E# B) `5 u
- exists* ~. q& R: C3 p! b- X2 p# E ]
- 判断key是否存在。存在 true 不在 false8 r/ [: n$ }4 G/ u0 ^
" W9 S m; W$ R+ F, q- incr, incrBy
0 j A: J% N* _ - key中的值进行自增1,如果填写了第二个参数,者自增第二个参数所填的值" Y7 G7 E. a. }- N6 i
- $redis->incr('key1');! m' b7 q' L$ i$ B% t
- $redis->incrBy('key1', 10);
- W9 m; O \2 o0 |/ j. u3 Q) N
1 F+ M; A1 Z( t4 M- decr, decrBy
9 V; X" l! E9 T8 E& p- p/ T* A - 做减法,使用方法同incr
* H' ^& b. K; J$ C/ X* @
! B. ^( n! p9 C" \- getMultiple
S: J% P/ _8 C: Z6 n) i - 传参; E. U7 r* B, U( X% F: x4 b
- 由key组成的数组
3 J# K2 v% h J+ H0 e - 返回参数) X# g0 m$ a, R& ^3 E6 j8 K" a
- 如果key存在返回value,不存在返回false. e, v$ s9 }# `8 v
- $redis->set('key1', 'value1'); $redis->set('key2', 'value2'); $redis->set('key3', 'value3'); $redis->getMultiple(array('key1', 'key2', 'key3'));
* ?4 i% f" P. | - $redis->lRem('key1', 'A', 2);* \9 ]5 x) j1 E& k( L( I
- $redis->lRange('key1', 0, -1);9 _, }- I. g, v6 ~
5 ?4 ~6 j+ }# S- list相关操作
, @& x" l8 r; W$ g% g' V5 {' z - lPush
2 a% D, {$ k9 {/ W8 K% j1 F - $redis->lPush(key, value);3 H! f C$ z+ k. {
- 在名称为key的list左边(头)添加一个值为value的 元素
) }, x* J. ?4 P1 l% [
8 ~$ w/ M: w m/ S- rPush' {! E2 r* `: ~
- $redis->rPush(key, value);/ d( J2 ^% N3 V/ U* p% }/ j
- 在名称为key的list右边(尾)添加一个值为value的 元素5 N. z$ q) k8 T! A/ v
- U8 B0 f! j9 z5 {0 n
- lPushx/rPushx
4 @0 W& x2 F1 D F' ~ H - $redis->lPushx(key, value);
) U5 J+ [$ x( Q* |7 f# Z0 _, v - 在名称为key的list左边(头)/右边(尾)添加一个值为value的元素,如果value已经存在,则不添加
$ D* w" O: b6 I" u/ W
, h5 x5 k' }; T1 x- lPop/rPop
) r! B, s0 l! w6 q# L+ d C - $redis->lPop('key');. {) t; ?( H- Q; Z/ B
- 输出名称为key的list左(头)起/右(尾)起的第一个元素,删除该元素( _! M6 U5 x1 u4 \# w/ X
- ; E' ^/ N" b, L, Q$ ?$ J) L( Y
- blPop/brPop, N* G9 [: F# P w3 j+ _3 Y
- $redis->blPop('key1', 'key2', 10);# ^2 }2 Y3 V% `9 s7 o& s, V$ U0 N5 Y
- lpop命令的block版本。即当timeout为0时,若遇到名称为key i的list不存在或该list为空,则命令结束。如果timeout>0,则遇到上述情况时,等待timeout秒,如果问题没有解决,则对keyi+1开始的list执行pop操作+ P" R, `. r' f. }
0 \* {: Y% `+ Q+ M/ y/ @8 b* X- lSize0 d" {6 Q; ?- z/ p7 e0 {" y
- $redis->lSize('key');$ i0 U% {) \4 w! Z. ]" c" h2 a! K
- 返回名称为key的list有多少个元素9 d* `7 L+ J/ M9 I" \: }; K* z
6 n: z# _2 l1 h6 N. D" J% V- lIndex, lGet# \4 l+ t7 Y, t2 X
- $redis->lGet('key', 0);3 n/ t2 E6 n% ^; T6 R0 g* n2 d
- 返回名称为key的list中index位置的元素+ L7 z9 T2 ]# P- ^: N
/ r: h ^6 l) N5 x+ [2 j5 l- lSet
1 X4 M6 g' Y0 J. } - $redis->lSet('key', 0, 'X');1 k7 u) }5 o& K2 |2 ?3 w) G' Z. E- p
- 给名称为key的list中index位置的元素赋值为value
- {% \' Z# \/ a# u6 a, b. B' o. H
3 d+ p1 i1 R8 f: q# ?, w% `% Q- lRange, lGetRange
1 H% C- R) \! O$ H% D6 R% |! S - $redis->lRange('key1', 0, -1);; S) J4 Z% b8 }* P* ^1 s. x
- 返回名称为key的list中start至end之间的元素(end为 -1 ,返回所有)/ r8 S2 {2 x5 a* r; m( \) y/ ]8 [
- \5 _& t, |; b, ^: C- lTrim, listTrim2 A% j! H% G0 O+ \+ V. I
- $redis->lTrim('key', start, end);7 a9 e0 b8 Y4 U5 k8 B" v, u$ t
- 截取名称为key的list,保留start至end之间的元素* p* v* a4 x' r# k
- / }) i. D( ]! J: P" j
- lRem, lRemove
' x0 x; ?" c) x3 }1 R. w: O - $redis->lRem('key', 'A', 2);
; W+ p8 x% ^3 ]! h) X - 删除count个名称为key的list中值为value的元素。count为0,删除所有值为value的元素,count>0从头至尾删除count个值为value的元素,count<0从尾到头删除|count|个值为value的元素( A% f( u$ h- `1 N8 o2 X) [/ h
- 4 x' v8 n* `9 w" x7 U
- lInsert
9 H9 m7 ~6 K( d" W - 在名称为为key的list中,找到值为pivot 的value,并根据参数Redis::BEFORE | Redis::AFTER,来确定,newvalue 是放在 pivot 的前面,或者后面。如果key不存在,不会插入,如果 pivot不存在,return -14 U8 w9 p. Q( y8 G
- $redis->delete('key1'); $redis->lInsert('key1', Redis::AFTER, 'A', 'X'); $redis->lPush('key1', 'A'); $redis->lPush('key1', 'B'); $redis->lPush('key1', 'C'); $redis->lInsert('key1', Redis::BEFORE, 'C', 'X');
8 m& z& \% c1 |/ n3 }$ f3 J- k - $redis->lRange('key1', 0, -1);
' @: [3 h' h( N7 C) e - $redis->lInsert('key1', Redis::AFTER, 'C', 'Y'); T% F4 \- w( R$ v4 G% b
- $redis->lRange('key1', 0, -1);
2 a: t* l9 e' v9 u - $redis->lInsert('key1', Redis::AFTER, 'W', 'value');
7 {7 Z- h4 \& x' D% `
# ]2 A0 ]6 A: E- rpoplpush$ V) s# R& w' N9 n4 e( S8 r
- 返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部
% L- a- A' b4 {% t2 u8 y0 g( A - $redis->delete('x', 'y');' O# y, S# @/ O
- $redis->lPush('x', 'abc'); $redis->lPush('x', 'def'); $redis->lPush('y', '123'); $redis->lPush('y', '456'); // move the last of x to the front of y. var_dump($redis->rpoplpush('x', 'y'));# e4 ^! f' X9 I3 z5 g& a6 c
- var_dump($redis->lRange('x', 0, -1));
4 q9 U4 x2 P7 O1 j' |2 C - var_dump($redis->lRange('y', 0, -1));
8 q8 f `$ O9 R" O* X
$ r5 |, C3 ^3 b' o! z6 v- string(3) "abc"
, o6 V" O! M4 N& s - array(1) { [0]=> string(3) "def" } 3 ~* E2 P, E( i" }% b% h5 k& o1 p+ c
- array(3) { [0]=> string(3) "abc" [1]=> string(3) "456" [2]=> string(3) "123" }
3 N" y' \3 W; a l, q
# _5 x4 ]5 H3 e. ~- SET操作相关9 W" ?# `8 y& w6 k' m
- sAdd0 i a" ~5 Z3 w, h& {; i
- 向名称为key的set中添加元素value,如果value存在,不写入,return false
1 O& x; r. c8 Y5 y U0 q5 \ - $redis->sAdd(key , value);
. `* D9 H0 f. Y; C3 H - 6 o$ n* s8 n9 Y' m0 e
- sRem, sRemove
5 ?* i9 {# l- `/ J - 删除名称为key的set中的元素value
' w0 `2 {% J/ l q* a7 Q - $redis->sAdd('key1' , 'set1');
" I* v- J; u" Y! b" r& t+ `, r - $redis->sAdd('key1' , 'set2');
: K$ N) \" f( d4 L# b1 ^ - $redis->sAdd('key1' , 'set3');
3 ]1 L* f4 |( R# x - $redis->sRem('key1', 'set2');
7 w* S& d( Q2 Z9 Y- a - 8 c0 i+ w1 \: k
- sMove
, ]! u/ c4 C8 u* h% p% M9 K6 V1 e - 将value元素从名称为srckey的集合移到名称为dstkey的集合' C& X% p) R3 [7 I2 ^3 D
- $redis->sMove(seckey, dstkey, value);: [" p( y5 {/ D' Z
0 Z# M; v4 o% y& t. B% {+ L# E- sIsMember, sContains5 }6 W* @' m& @; d' C
- 名称为key的集合中查找是否有value元素,有ture 没有 false
, j3 S- ]4 _! q. ]' Q - $redis->sIsMember(key, value);
3 l" X+ r2 H( ^
9 M- D( W) m" y$ ]) z9 ?- sCard, sSize; o1 A- ?+ W8 e+ b; k$ J
- 返回名称为key的set的元素个数) K5 x" K S5 }% b' ]
- ) k! u) F6 d8 Z! o
- sPop; ?' t# D6 s$ I0 Z$ Z4 h4 M, U1 |. p
- 随机返回并删除名称为key的set中一个元素: s" B- u- }: U" X
/ H3 F6 t+ |, O- sRandMember
# b- o: s/ s( A5 U6 J3 E - 随机返回名称为key的set中一个元素,不删除% o7 M5 w3 D# P4 H; F5 M
- $ p0 Y8 y8 E& E6 k* z
- sInter: I1 d* j& R$ u
- 求交集
, _; b3 N- u) g( f { - 0 P) b! G( H4 P
- sInterStore
3 v, z* I ^; _, j3 n - 求交集并将交集保存到output的集合
. X. @: j w( h6 @$ { - $redis->sInterStore('output', 'key1', 'key2', 'key3')
8 w z; q; Z0 H" U3 V* A
. b1 P0 `3 H% [6 k9 y( D2 i M- sUnion6 v+ ?0 g* d1 X* M" I
- 求并集% Q: d3 n. q; n, A6 K
- $redis->sUnion('s0', 's1', 's2');
. R. d) k3 X* o" f+ t - s0,s1,s2 同时求并集* Y/ J- V) ?2 |4 a# O6 g. k
- . E/ U2 D! f w8 L4 S: _5 f
- sUnionStore
8 p2 @0 S& t+ A. { - 求并集并将并集保存到output的集合# @4 u4 v1 ^1 e9 m& I. C
- $redis->sUnionStore('output', 'key1', 'key2', 'key3');& n" o2 l' O; |- p
6 ~5 P; D9 t) O* p$ M8 j- J! W# ~- sDiff
' E$ H. e; ]. w( i( ]: _ - 求差集% F) Y2 ^* A. [3 K. R3 J) G
- 1 o+ H7 Y% ^8 B, b+ u q0 r2 r
- sDiffStore7 m, s* [4 G+ i, K
- 求差集并将差集保存到output的集合/ L8 t6 Y; y9 O/ b8 t# c
- & j6 c) u j4 o' E, S
- sMembers, sGetMembers
. ^% r# ]% X( ~ - 返回名称为key的set的所有元素
$ a/ s" x8 v$ t0 U$ w! u9 N' b+ M
7 s: R h6 c6 v; j" v: Z. ]5 z9 d- sort3 d+ N" R9 t$ E+ _6 \1 L
- 排序,分页等
$ @8 n" F! _2 B. Z2 O" W2 O+ g - 参数
k5 ^. } l" _" I& Q" \ - 'by' => 'some_pattern_*',8 e2 n: W9 A& L: @' Z m# I
- 'limit' => array(0, 1),8 I. ]) Q6 n$ k0 y/ e& A# d, [
- 'get' => 'some_other_pattern_*' or an array of patterns,
* v C8 m" k( k2 w5 V2 ` - 'sort' => 'asc' or 'desc',/ ^/ F% c, Y2 p& Z/ |
- 'alpha' => TRUE,
6 o, c% d% S( z! |0 |( s - 'store' => 'external-key'
( A! C; J, V5 Q7 }/ h! | - 例子* U+ C- D& c2 e5 r8 H" ?
- $redis->delete('s'); $redis->sadd('s', 5); $redis->sadd('s', 4); $redis->sadd('s', 2); $redis->sadd('s', 1); $redis->sadd('s', 3);
+ ^* ^* M# x! X3 M/ Y: S L, @8 \7 i7 m - var_dump($redis->sort('s')); // 1,2,3,4,53 X7 E3 l. u0 U9 r
- var_dump($redis->sort('s', array('sort' => 'desc'))); // 5,4,3,2,1" h7 }- a, b* @8 F/ R
- var_dump($redis->sort('s', array('sort' => 'desc', 'store' => 'out'))); // (int)5
S7 E k4 L- n! @ -
/ f# m( d3 d/ i9 e# v6 m+ L - string命令+ E! O. h% e0 s; e3 O
- getSet
! |7 ]% C' @# g - 返回原来key中的值,并将value写入key
% \7 q, m2 ?7 o6 z* B5 a6 U b - $redis->set('x', '42');
$ J# o6 }" e; ^2 A3 d - $exValue = $redis->getSet('x', 'lol'); // return '42', replaces x by 'lol'
4 Z+ y7 \, m! W, Q7 n4 \ - $newValue = $redis->get('x')' // return 'lol'
0 p: V6 z3 y# P: h4 V- _ - ( F" p. T0 x8 `. v1 i9 f
- append1 \' i2 z4 l- o9 b% }! |. c$ c
- string,名称为key的string的值在后面加上value* X) V, }5 d: m+ b" r+ Y/ S
- $redis->set('key', 'value1');' b* D' d: r4 \( _1 s2 @
- $redis->append('key', 'value2');
& x0 R) O/ u, u) d C. D w - $redis->get('key');
. v5 O. l. @: S
8 J% o$ w3 T2 y+ d% b- getRange (方法不存在)4 Z& r# y4 O+ ?# Z) H$ Z, O' |
- 返回名称为key的string中start至end之间的字符1 ~5 q1 p$ F2 H% L
- $redis->set('key', 'string value');
! m2 C, N3 [8 L$ Y& ~: u - $redis->getRange('key', 0, 5);9 D* Z9 n% `1 a% e
- $redis->getRange('key', -5, -1);
" w5 o' d# L. p& X+ ` - 7 [- @4 [3 K' t
- setRange (方法不存在); o6 ~- W" h' H$ P# v; K
- 改变key的string中start至end之间的字符为value: \1 s* a7 x6 ?7 ~
- $redis->set('key', 'Hello world');
7 H/ l4 J# P! f' z - $redis->setRange('key', 6, "redis");
; D9 R9 |* d7 T8 i - $redis->get('key');- C0 }8 P2 [# E4 r
/ k9 W* m& e" N" J- ~4 X- strlen
# @9 ]% @1 C* h2 e+ s - 得到key的string的长度: z) o1 y" J6 H8 U, I
- $redis->strlen('key');/ Y3 H( ?1 g- X! D5 {1 Q/ ]3 k+ _
- 0 f' h* z" F6 Q
- getBit/setBit7 v1 p0 U1 K0 i) ~: B& |4 q4 B
- 返回2进制信息
U! m* \ w$ X* O - 4 I* \8 @# z6 y9 ^4 K: [$ |- [
- zset(sorted set)操作相关
& e; l9 C% T5 M4 M% T) k - zAdd(key, score, member):向名称为key的zset中添加元素member,score用于排序。如果该元素已经存在,则根据score更新该元素的顺序。
6 [* B, h( n7 \3 x1 G1 n - $redis->zAdd('key', 1, 'val1');
: ^0 x x6 J8 k0 Q/ V A2 J - $redis->zAdd('key', 0, 'val0');
1 B( G0 E* @+ {* |5 l - $redis->zAdd('key', 5, 'val5');
4 Y6 z' O1 j8 t: M - $redis->zRange('key', 0, -1); // array(val0, val1, val5) v B1 [, ], l3 X/ K8 Z
/ j2 u) X% d/ E. u- zRange(key, start, end,withscores):返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的所有元素
2 q) B/ B4 O% x$ ]7 w G* S - $redis->zAdd('key1', 0, 'val0');
, H5 E- j: Z9 g* b. ?4 w - $redis->zAdd('key1', 2, 'val2');2 R$ ?( J% }2 ^8 @
- $redis->zAdd('key1', 10, 'val10');
* T' r3 l; l6 | - $redis->zRange('key1', 0, -1); // with scores $redis->zRange('key1', 0, -1, true);9 K2 N( s( T# c$ J7 o3 u
) E6 }1 O& K" g* O% B- zDelete, zRem$ T8 S, W' R& A! Y2 G- _/ e
- zRem(key, member) :删除名称为key的zset中的元素member& ? _% X, F# Q# O
- $redis->zAdd('key', 0, 'val0');
: M+ k8 E4 S! x% M - $redis->zAdd('key', 2, 'val2');7 M0 n4 \( i/ V- \
- $redis->zAdd('key', 10, 'val10');
I- g0 Y% y* w# h7 Z - $redis->zDelete('key', 'val2');
% q, y" H; ~1 z- R* n7 z - $redis->zRange('key', 0, -1); $ |3 d1 h& o9 [& ^4 U% C
2 ]' N$ D: j: z1 s5 r0 f- zRevRange(key, start, end,withscores):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素.withscores: 是否输出socre的值,默认false,不输出
, |/ h, D* Z) V% A& T3 I: W - $redis->zAdd('key', 0, 'val0');
" X1 U( U0 m; y- E! E7 H) T, L - $redis->zAdd('key', 2, 'val2');
m3 X& M" z; Z' X& u - $redis->zAdd('key', 10, 'val10');
' u, P8 r4 p) h! w - $redis->zRevRange('key', 0, -1); // with scores $redis->zRevRange('key', 0, -1, true);7 ]- N) b5 F2 y0 u& T5 d1 `5 d
+ T5 j; h# s/ K: x! J6 ^' y- [# K' E- zRangeByScore, zRevRangeByScore
; S! D% [& e; ]; z1 G) n# E5 M1 e - $redis->zRangeByScore(key, star, end, array(withscores, limit ));" V0 a2 o5 Q1 c& B
- 返回名称为key的zset中score >= star且score <= end的所有元素
* H* h6 P1 Y: o8 y/ ]9 n5 `/ X4 v; o3 f# Q
; v6 ^7 W Y4 |/ z- zCount, u K5 h- Q( d" f! ]' V
- $redis->zCount(key, star, end);
) Y% m6 s' S/ [ P! e9 g3 i - 返回名称为key的zset中score >= star且score <= end的所有元素的个数
% d: H1 h) }0 V' ^# c - " C- S; A: S: h/ O0 U& A: i$ I1 ]
- zRemRangeByScore, zDeleteRangeByScore
" k9 b% p' S* ? H4 H8 P4 u - $redis->zRemRangeByScore('key', star, end);- e# z! x0 a/ l- L
- 删除名称为key的zset中score >= star且score <= end的所有元素,返回删除个数4 e1 z& Y8 @3 A
* j( j2 H: P8 A2 m3 q2 r* j- zSize, zCard
% K* U$ j. G; P! i3 a - 返回名称为key的zset的所有元素的个数
* Q g; f" C+ b. U - ! Z! D* {' F! [+ B n$ e8 T0 y
- zScore3 L3 f7 E: W* g; D) P, S: K
- $redis->zScore(key, val2);
& u: q& Y# ]2 b, {* V8 q* j# P5 X - 返回名称为key的zset中元素val2的score9 z- O# Y* V/ a' n$ q8 Y4 t
+ u/ j8 ^5 r2 \2 |- zRank, zRevRank+ I1 z, N% s' u
- $redis->zRevRank(key, val);6 p' N; C* y1 i9 ~" N
- 返回名称为key的zset(元素已按score从小到大排序)中val元素的rank(即index,从0开始),若没有val元素,返回“null”。zRevRank 是从大到小排序
7 L% E" x2 O. m' T; b. S
2 {8 O4 l4 [6 }* q- zIncrBy! _) x! z! B2 o) J5 w3 E8 s
- $redis->zIncrBy('key', increment, 'member');
0 A- x2 f, R9 {3 R - 如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment6 u8 a$ I; Z* I
- ; I6 w$ W4 K; p" p
- zUnion/zInter
# E4 w* a5 w9 e v$ O0 t - 参数% M4 @( O" `) F/ Y& o: B. ^' l
- keyOutput
# R7 b; K: |) Z1 P4 z) j- S# k0 w - arrayZSetKeys
, f% z3 l r% F- K+ A1 M4 F7 e - arrayWeights, E+ M2 ~( T! g
- aggregateFunction Either "SUM", "MIN", or "MAX": defines the behaviour to use on duplicate entries during the zUnion.
P- f& S3 Z* Q - 对N个zset求并集和交集,并将最后的集合保存在dstkeyN中。对于集合中每一个元素的score,在进行AGGREGATE运算前,都要乘以对于的WEIGHT参数。如果没有提供WEIGHT,默认为1。默认的AGGREGATE是SUM,即结果集合中元素的score是所有集合对应元素进行SUM运算的值,而MIN和MAX是指,结果集合中元素的score是所有集合对应元素中最小值和最大值。
+ z! W# ]5 ]! A$ h" R/ q* R9 z% \
复制代码
9 L, H$ C' w3 R. X6 \8 ^$ ^) f! j+ i$ c2 A) y6 s# D
$ B# Z- s4 ?5 d- S! M2 ^) \0 l' t- Q: B- ~' y/ Y L0 V; B4 r
|
|