PHP 操作 Redis 之 phpredis 擴充套件

xugege發表於2019-08-05
  • phpredis是redis的php的一個擴充套件,效率是相當高有連結串列排序功能,對建立記憶體級的模組業務關係很有用

    $redis = new Redis();
    $redis->connect('127.0.0.1', 6379);
    $redis->auth('123456');

    key鍵

    //DEL key [key ...]------刪除給定的一個或多個key
    $a = $redis->del(array('xrj','ly','fjf'));
    //KEYS pattern------查詢所有符合給定模式pattern的key
    $b = $redis->keys('*');
    //RANDOMKEY------從當前資料庫中隨機返回(不刪除)一個key
    $c = $redis->randomkey();
    //TTL key------以秒為單位,返回給定key的剩餘生存時間(TTL, time to live)
    //PTTL key------以毫秒為單位,返回給定key的剩餘生存時間
    $d = $redis->ttl('bbs');
    //EXISTS key------檢查給定key是否存在,存在,返回1,否則返回0
    $e = $redis->exists('email');
    //MOVE key db------將當前資料庫的key移動到給定的資料庫db當中
    $f = $redis->move('email',1);
    $redis->select(1);
    $f = $redis->keys('*');
    $f = $redis->move('email',0);
    //RENAME key newkey------將key改名為newkey
    $g = $redis->rename('email','e-eamil.com');
    $g = $redis->rename('e-eamil.com','eamil');
    //RENAMENX key newkey------當且僅當newkey不存在時,將key改名為newkey
    $h = $redis->renamenx('bbs','bbs1');
    //TYPE key------返回key所儲存的值的型別
    $i = $redis->type('pageview');
    //EXPIRE key seconds------給key設定生存時間,當key過期時,它會被自動刪除
    //PEXPIRE key milliseconds------以毫秒為單位設定key的生存時間
    //EXPIREAT key timestamp------命令接受的時間引數是UNIX時間戳,key存活到一個unix時間戳時間
    //PERSIST key------移除給定key的生存時間,轉換成一個不帶生存時間,永不過期的key
    //SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC | DESC] [ALPHA] [STORE destination]------返回或儲存<br>給定列表、集合、有序集合key中經過排序的元素    

    String(字串)相關操作

    //SET key value------將字串值value關聯到key,會覆蓋
    $a = $redis->set('email','jiang@58haha.cn');
    //SETNX key value------將key的值設為value,當且僅當key不存在的時候,成功返回1,不成功返回0
    $b = $redis->setnx('email','jiang@58haha.cn');
    //SETEX key seconds value------將值value關聯到key,並將key的生存時間設為seconds(以秒為單位)
    $c = $redis->setex('name',10086,'江');
    //PSETEX key milliseconds value------命令和SETEX命令相似,它以毫秒為單位設定key的生存時間
    $d = $redis->psetex('jiang',90000,'哈哈哈');
    //MSET key value [key value ...]------同時設定一個或多個key-value對
    $e = $redis->mset(array('ly' => 'liyang', 'fjf' => 'fengjingfeng'));
    //MSETNX key value [key value ...]------同時設定一個或多個key-value對,當且僅當所給定key都不存在
    $f = $redis->msetnx(array('ly' => 'liyang', 'xrj'=>'xingrongjiang', 'fjf' => 'fengjingfeng'));
    //APPEND key value------如果key已經存在並且是一個字串,APPEND命令將value追加到key原來的值的末尾。如果key不存在,APPEND就像執行SET key value一樣   
    $g = $redis->append('ly','love');
    //GET key------返回key所關聯的字串值,如果key不存在那麼返回特殊值nil,GET只能用於處理字串值  
    $h = $redis->get('ly');
    //MGET key [key ...]------返回所有(一個或多個)給定key的值,如果給定的key裡面有某個key不存在,那麼這個key返回特殊值nil,命令永不失敗   
    $i = $redis->mget(array('email','ly','fjf'));
    //GETRANGE key start end------返回key中字串值的子字串,字串的擷取範圍由start和end兩個偏移量決定(包括start和end在內),負數偏移量表示從字串最後<br>開始計數,-1表示最後一個字元,-2表示倒數第二個    <br>
    $j = $redis->getrange('email',0,-1); //從第一個到最後一個,相當於直接get
    //GETSET key value------將給定key的值設為value,並返回key的舊值(old value)
    $k = $redis->getset('email','jiangzunshao@163.com');
    //STRLEN key------返回key所儲存的字串值的長度
    $l = $redis->strlen('email');
    //DECR key------將key中儲存的數字值減一,如果key不存在,那麼key的值會先被初始化為0,然後再執行DECR操作   
    $m = $redis->decr('pageview');
    //INCR key------將key中儲存的數字值增一,如果key不存在,那麼key的值會先被初始化為0,然後再執行INCR操作   
    $n = $redis->incr('pageview1');
    //DECRBY key decrement------將key所儲存的值減去減量decrement(可以為負值)   
    $o = $redis->decrby('pageview',3);
    //INCRBY key increment------將key所儲存的值加上增量increment(可以為負值)   
    $p = $redis->incrby('pageview',6);

    Hash(雜湊表)相關操作

    //HSET key field value------將雜湊表key中的域field的值設為value,新建返回1,覆蓋返回0
    $a = $redis->hset("user","jiang@58haha.cn","{'name':'jiangzunshao','age':25,'work':'php','city':'BeiJing'}");   
    //HSETNX key field value------將雜湊表key中的域field的值設定為value,當且僅當域field不存在的時候. 設定成功,返回1。如果已經存在且沒有操作被執行,返回0   
    $b = $redis->hsetnx("user","jiang@58haha.cn","{'name':'jiangzunshao','age':25,'work':'php','city':'BeiJing'}");   
    //HGET key field------返回雜湊表key中給定域field的值
    $c = $redis->hget("user","jiang@58haha.cn");
    //HMSET key field value [field value ...]------同時將多個field-value(域-值)對設定到雜湊表 key中
    $d = $redis->hmset('user',array('name'=>'jiangzunshao', 'age' => 20));
    //HMGET key field [field ...]------返回雜湊表 key中,一個或多個給定域的值
    $f = $redis->hmGet('user', array('name', 'age'));
    //HGETALL key------返回雜湊表key中,所有的域和值
    $g = $redis->hgetall('user');
    //HDEL key field [field ...]------刪除雜湊表key中的一個或多個指定域,不存在的域將被忽略
    $h = $redis->hdel('user','age');
    //HLEN key------返回雜湊表key中域的數量
    $i = $redis->hlen('user');
    //HEXISTS key field------檢視雜湊表key中,給定域field是否存在,存在返回1,不存在返回0
    $g = $redis->hexists('user','jiang@58haha.cn');
    //HINCRBY key field increment------為雜湊表key中的域field的值加上增量increment,可以為負
    $k = $redis->hincrby('user','pv',5);
    //HKEYS key------返回雜湊表key中的所有域
    $l = $redis->hkeys('user');
    //HVALS key------返回雜湊表key中所有域的值
    $m = $redis->hvals('user');

List(列表)相關操作

//LPUSH key value [value ...]------將資料插入列表的頭部
$redis->lpush('dbs','mongodb-3.2');
//RPUSH key value [value ...]------將資料插入列表的尾部
$redis->rpush('dbs','redis');
//LLEN key------獲取列表的長度
$c = $redis->llen('dbs');
//LPOP key------移除並返回列表的頭元素
$d = $redis->lpop('dbs');
//RPOP key------移除並返回列表的尾元素
$e = $redis->rpop('dbs');
//LRANGE key start stop------返回列表中指定區間內元素
$f = $redis->lrange('dbs',0,$redis->llen('dbs'));
$f = $redis->lrange('dbs',0,-1);
//LSET key index value------將列表下標為index的元素的值設定為value
$h = $redis->lset('dbs',1,'jiang');
//LTRIM key start stop------列表只保留指定區間內的元素
$i = $redis->ltrim('dbs',3,5);
//LINDEX key index------返回列表中下標為index的元素
$e = $redis->lindex('dbs',$redis->llen('dbs')-1);
//LINSERT key BEFORE|AFTER pivot value------將值value插入到列表當中,位於值pivot之前或之後
$g = $redis->linsert('dbs',Redis::BEFORE,'mysql','mysqlmysql');
$g = $redis->linsert('dbs',Redis::AFTER,'redis','redisredis'); 
//RPOPLPUSH source destination------命令RPOPLPUSH在一個原子時間內執行以下兩個動作:1,將列表source中的最後一個元素(尾元素)彈出,並返回給客戶端<br>;<br>2,將source彈出的元素插入到列表destination,作為destination列表的的頭元素   
$k = $redis->rpoplpush('dbs1','dbs');

Set(集合)相關操作

//SADD key member [member ...]------將一個或多個member元素加入到集合key當中,已經存在於集合的member元素將被忽略   
$a = $redis->sadd('set', 'xingrongjiang');
//SREM key member [member ...]------移除集合key中的一個或多個member元素,不存在的member元素會被忽略   
$b = $redis->srem('set','Array');
//SMEMBERS key------返回集合key中的所有成員
$c = $redis->smembers('set');
//SISMEMBER key member------判斷member元素是否集合key的成員
$d = $redis->sismember('set','liyang');
//SCARD key------返回集合key的基數(集合中元素的數量)
$e = $redis->scard('set');
//SMOVE source destination member------將member元素從source集合移動到destination集合
$f = $redis->smove('set','set1','xingrongjiang');
//SPOP key------移除並返回集合中的一個隨機元素
$g = $redis->spop('set');
//SRANDMEMBER key [count]------如果只提供了key引數,那麼返回集合中的一個隨機元素;如果count為正數,且小於集合基數,返回一個包含count個元素的陣列,陣列中<br>的元素各不相同;如果count大於等於集合基數,返回整個集合;如果count為負數,那麼命令返回一個陣列,陣列中的元素可能會重複出現多次,而陣列的長度為count的絕對值   
$h = $redis->srandmember('set',2);
//SINTER key [key ...]------返回一個集合的全部成員,該集合是所有給定集合的交集
$i = $redis->sinter('set');
//SINTERSTORE destination key [key ...]------類似於SINTER命令,它將結果儲存到destination集合,而不是簡單地返回結果集   
$j = $redis->sinterstore('haha','set');
//SUNION key [key ...]------返回一個集合的全部成員,該集合是所有給定集合的並集
$k = $redis->sunion('set','set1');
//SUNIONSTORE destination key [key ...]------類似於SUNION命令,它將結果儲存到destination集合,而不是簡單地返回結果集   
$l = $redis->sunionstore('haha1','haha','set1');
//SDIFF key [key ...]------返回一個集合的全部成員,該集合是所有給定集合之間的差集
$m = $redis->sdiff('set','set1');

有序集(Sorted set)相關操作

//ZADD key score member------向名稱為key的zset中新增元素member,score用於排序,如果該元素已經存在,則根據score更新該元素的順序 
$a = $redis->zadd('site', 10, 'google.com');
$a = $redis->zadd('site', 9, 'baidu.com');
$a = $redis->zadd('site', 8, 'sina.com.cn');
//ZREM key member------刪除名稱為key的zset中的元素member
// $b = $redis->zrem('site','sina.com.cn');
//ZCARD key------返回名稱為key的zset的所有元素的個數
$c = $redis->zcard('site');
//ZCOUNT key min max------返回有序集key中,score值在min和max之間的成員的數量
$d = $redis->zcount('site',6,9);
//ZSCORE key member------返回有序集key中,成員member的score值
$e = $redis->zscore('site','baidu.com');
//ZINCRBY key increment member------為有序集key的成員member的score值加上增量increment,返回值就是score加上increment的結果 
$f = $redis->zincrby('site',10,'baidu.com');
//ZRANGE key start stop [WITHSCORES]------返回有序集key中,指定區間內的成員,其中成員的位置按score值遞增(從小到大)來排序 
$j = $redis->zrange('site',0,-1);
$j = $redis->zrange('site',0,-1,true);
//ZREVRANGE key start stop [WITHSCORES]------返回有序集key中,指定區間內的成員,其中成員的位置按score值遞減(從大到小)來排列 
$h = $redis->zrevrange('site',0,-1);
$h = $redis->zrevrange('site',0,-1,true);

Connection(連線)

//AUTH password------密碼認證
$a = $redis->auth('123456');
//PING------檢視連線狀態
$b = $redis->ping();
//SELECT index------切換到指定的資料庫,資料庫索引號index用數字值指定,以0作為起始索引值,預設使用0號資料庫   
$c = $redis->select(1);

Server(伺服器)

//TIME------返回當前伺服器時間,一個包含兩個字串的列表:第一個字串是當前時間(以UNIX時間戳格式表示),而第二個字串是當前這一秒鐘已經逝去的微秒數   
$a = $redis->time();
//DBSIZE-----返回當前資料庫的key的數量
$b = $redis->dbsize();
//BGREWRITEAOF------使用aof來進行資料庫持久化
$c = $redis->bgrewriteaof();
//SAVE------將資料同步儲存到磁碟
$d = $redis->save();
//BGSAVE------將資料非同步儲存到磁碟 
$e = $redis->bgsave();
//LASTSAVE------返回上次成功將資料儲存到磁碟的Unix時戳
$f = $redis->lastsave();
//SLAVEOF host port------選擇從伺服器
$redis->slaveof('10.0.1.7', 6379);
//FLUSHALL------清空整個Redis伺服器的資料(刪除所有資料庫的所有key)
$redis->flushall();
//FLUSHDB------清空當前資料庫中的所有key
$redis->flushdb();
//INFO [section]------返回關於 Redis 伺服器的各種資訊和統計數值
$g = $redis->info()

相關文章