Home >Backend Development >PHP Tutorial >How to use Redis function in PHP

How to use Redis function in PHP

小云云
小云云Original
2018-03-20 14:12:006405browse

I have been using PHP to use Redis, but it always feels unreliable. I simply use this time to complete it in one go. I have typed almost all the Redis commands in PHP, including its return value. , even if you forget next time, you can just come and check it~ You can use it with confidence.

Test environment: PHP:5.5 Redis:2.4.6
Reference URL: https://github.com/phpredis/phpredis

Tips :

For: string, set, sort set, hash add and change operations, it is the same command, but when it is used as a change operation, the timely and successful return value is still 0

For: list structure, there is a free set of methods for addition, deletion and modification.

<?php
/*1.Connection*/
  $redis = new Redis();
  $redis->connect(&#39;127.0.0.1&#39;,6379,1);//短链接,本地host,端口为6379,超过1秒放弃链接
  $redis->open(&#39;127.0.0.1&#39;,6379,1);//短链接(同上)
  $redis->pconnect(&#39;127.0.0.1&#39;,6379,1);//长链接,本地host,端口为6379,超过1秒放弃链接
  $redis->popen(&#39;127.0.0.1&#39;,6379,1);//长链接(同上)
  $redis->auth(&#39;password&#39;);//登录验证密码,返回【true | false】
  $redis->select(0);//选择redis库,0~15 共16个库
  $redis->close();//释放资源
  $redis->ping(); //检查是否还再链接,[+pong]
  $redis->ttl(&#39;key&#39;);//查看失效时间[-1 | timestamps]
  $redis->persist(&#39;key&#39;);//移除失效时间[ 1 | 0]
  $redis->sort(&#39;key&#39;,[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素,$array为参数limit等!【配合$array很强大】 [array|false]
/*2.共性的运算归类*/
  $redis->expire(&#39;key&#39;,10);//设置失效时间[true | false]
  $redis->move(&#39;key&#39;,15);//把当前库中的key移动到15库中[0|1]
//string
  $redis->strlen(&#39;key&#39;);//获取当前key的长度
  $redis->append(&#39;key&#39;,&#39;string&#39;);//把string追加到key现有的value中[追加后的个数]
  $redis->incr(&#39;key&#39;);//自增1,如不存在key,赋值为1(只对整数有效,存储以10进制64位,redis中为str)[new_num | false]
  $redis->incrby(&#39;key&#39;,$num);//自增$num,不存在为赋值,值需为整数[new_num | false]
  $redis->decr(&#39;key&#39;);//自减1,[new_num | false]
  $redis->decrby(&#39;key&#39;,$num);//自减$num,[ new_num | false]
  $redis->setex(&#39;key&#39;,10,&#39;value&#39;);//key=value,有效期为10秒[true]
//list
  $redis->llen(&#39;key&#39;);//返回列表key的长度,不存在key返回0, [ len | 0]
//set
  $redis->scard(&#39;key&#39;);//返回集合key的基数(集合中元素的数量)。[num | 0]
  $redis->sMove(&#39;key1&#39;, &#39;key2&#39;, &#39;member&#39;);//移动,将member元素从key1集合移动到key2集合。[1 | 0]
//Zset
  $redis->zcard(&#39;key&#39;);//返回集合key的基数(集合中元素的数量)。[num | 0]
  $redis->zcount(&#39;key&#39;,0,-1);//返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]
//hash
  $redis->hexists(&#39;key&#39;,&#39;field&#39;);//查看hash中是否存在field,[1 | 0]
  $redis->hincrby(&#39;key&#39;,&#39;field&#39;,$int_num);//为哈希表key中的域field的值加上量(+|-)num,[new_num | false]
  $redis->hlen(&#39;key&#39;);//返回哈希表key中域的数量。[ num | 0]
/*3.Server*/
  $redis->dbSize();//返回当前库中的key的个数
  $redis->flushAll();//清空整个redis[总true]
  $redis->flushDB();//清空当前redis库[总true]
  $redis->save();//同步??把数据存储到磁盘-dump.rdb[true]
  $redis->bgsave();//异步??把数据存储到磁盘-dump.rdb[true]
  $redis->info();//查询当前redis的状态 [verson:2.4.5....]
  $redis->lastSave();//上次存储时间key的时间[timestamp]
  $redis->watch(&#39;key&#39;,&#39;keyn&#39;);//监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 [true]
  $redis->unwatch(&#39;key&#39;,&#39;keyn&#39;);//取消监视一个(或多个) key [true]
  $redis->multi(Redis::MULTI);//开启事务,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
  $redis->multi(Redis::PIPELINE);//开启管道,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
  $redis->exec();//执行所有事务块内的命令,;【事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值 false】
/*4.String,键值对,创建更新同操作*/
  $redis->setOption(Redis::OPT_PREFIX,&#39;hf_&#39;);//设置表前缀为hf_
  $redis->set(&#39;key&#39;,1);//设置key=aa value=1 [true]
  $redis->mset($arr);//设置一个或多个键值[true]
  $redis->setnx(&#39;key&#39;,&#39;value&#39;);//key=value,key存在返回false[|true]
  $redis->get(&#39;key&#39;);//获取key [value]
  $redis->mget($arr);//(string|arr),返回所查询键的值
  $redis->del($key_arr);//(string|arr)删除key,支持数组批量删除【返回删除个数】
  $redis->delete($key_str,$key2,$key3);//删除keys,[del_num]
  $redis->getset(&#39;old_key&#39;,&#39;new_value&#39;);//先获得key的值,然后重新赋值,[old_value | false]
/*5.List栈的结构,注意表头表尾,创建更新分开操作*/
  $redis->lpush(&#39;key&#39;,&#39;value&#39;);//增,只能将一个值value插入到列表key的表头,不存在就创建 [列表的长度 |false]
  $redis->rpush(&#39;key&#39;,&#39;value&#39;);//增,只能将一个值value插入到列表key的表尾 [列表的长度 |false]
  $redis->lInsert(&#39;key&#39;, Redis::AFTER, &#39;value&#39;, &#39;new_value&#39;);//增,将值value插入到列表key当中,位于值value之前或之后。[new_len | false]
  $redis->lpushx(&#39;key&#39;,&#39;value&#39;);//增,只能将一个值value插入到列表key的表头,不存在不创建 [列表的长度 |false]
  $redis->rpushx(&#39;key&#39;,&#39;value&#39;);//增,只能将一个值value插入到列表key的表尾,不存在不创建 [列表的长度 |false]
  $redis->lpop(&#39;key&#39;);//删,移除并返回列表key的头元素,[被删元素 | false]
  $redis->rpop(&#39;key&#39;);//删,移除并返回列表key的尾元素,[被删元素 | false]
  $redis->lrem(&#39;key&#39;,&#39;value&#39;,0);//删,根据参数count的值,移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value) [被移除的数量 | 0]
  $redis->ltrim(&#39;key&#39;,start,end);//删,列表修剪,保留(start,end)之间的值 [true|false]
  $redis->lset(&#39;key&#39;,index,&#39;new_v&#39;);//改,从表头数,将列表key下标为第index的元素的值为new_v, [true | false]
  $redis->lindex(&#39;key&#39;,index);//查,返回列表key中,下标为index的元素[value|false]
  $redis->lrange(&#39;key&#39;,0,-1);//查,(start,stop|0,-1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。[array|false]
/*6.Set,没有重复的member,创建更新同操作*/
  $redis->sadd(&#39;key&#39;,&#39;value1&#39;,&#39;value2&#39;,&#39;valuen&#39;);//增,改,将一个或多个member元素加入到集合key当中,已经存在于集合的member元素将被忽略。[insert_num]
  $redis->srem(&#39;key&#39;,&#39;value1&#39;,&#39;value2&#39;,&#39;valuen&#39;);//删,移除集合key中的一个或多个member元素,不存在的member元素会被忽略 [del_num | false]
  $redis->smembers(&#39;key&#39;);//查,返回集合key中的所有成员 [array | &#39;&#39;]
  $redis->sismember(&#39;key&#39;,&#39;member&#39;);//判断member元素是否是集合key的成员 [1 | 0]
  $redis->spop(&#39;key&#39;);//删,移除并返回集合中的一个随机元素 [member | false]
  $redis->srandmember(&#39;key&#39;);//查,返回集合中的一个随机元素 [member | false]
  $redis->sinter(&#39;key1&#39;,&#39;key2&#39;,&#39;keyn&#39;);//查,返回所有给定集合的交集 [array | false]
  $redis->sunion(&#39;key1&#39;,&#39;key2&#39;,&#39;keyn&#39;);//查,返回所有给定集合的并集 [array | false]
  $redis->sdiff(&#39;key1&#39;,&#39;key2&#39;,&#39;keyn&#39;);//查,返回所有给定集合的差集 [array | false]
/*7.Zset,没有重复的member,有排序顺序,创建更新同操作*/
  $redis->zAdd(&#39;key&#39;,$score1,$member1,$scoreN,$memberN);//增,改,将一个或多个member元素及其score值加入到有序集key当中。[num | 0]
  $redis->zrem(&#39;key&#39;,&#39;member1&#39;,&#39;membern&#39;);//删,移除有序集key中的一个或多个成员,不存在的成员将被忽略。[del_num | 0]
  $redis->zscore(&#39;key&#39;,&#39;member&#39;);//查,通过值反拿权 [num | null]
  $redis->zrange(&#39;key&#39;,$start,$stop);//查,通过(score从小到大)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
  $redis->zrevrange(&#39;key&#39;,$start,$stop);//查,通过(score从大到小)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
  $redis->zrangebyscore(&#39;key&#39;,$min,$max[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从小到大排)成员[array | null]
  $redis->zrevrangebyscore(&#39;key&#39;,$max,$min[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从大到小排)成员[array | null]
  $redis->zrank(&#39;key&#39;,&#39;member&#39;);//查,通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]
  $redis->zrevrank(&#39;key&#39;,&#39;member&#39;);//查,通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]
  $redis->ZINTERSTORE();//交集
  $redis->ZUNIONSTORE();//差集
/*8.Hash,表结构,创建更新同操作*/
  $redis->hset(&#39;key&#39;,&#39;field&#39;,&#39;value&#39;);//增,改,将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】
  $redis->hget(&#39;key&#39;,&#39;field&#39;);//查,取值【value|false】
  $arr = array(&#39;one&#39;=>1,2,3);$arr2 = array(&#39;one&#39;,0,1);
  $redis->hmset(&#39;key&#39;,$arr);//增,改,设置多值$arr为(索引|关联)数组,$arr[key]=field, [ true ]
  $redis->hmget(&#39;key&#39;,$arr2);//查,获取指定下标的field,[$arr | false]
  $redis->hgetall(&#39;key&#39;);//查,返回哈希表key中的所有域和值。[当key不存在时,返回一个空表]
  $redis->hkeys(&#39;key&#39;);//查,返回哈希表key中的所有域。[当key不存在时,返回一个空表]
  $redis->hvals(&#39;key&#39;);//查,返回哈希表key中的所有值。[当key不存在时,返回一个空表]
  $redis->hdel(&#39;key&#39;,$arr2);//删,删除指定下标的field,不存在的域将被忽略,[num | false]
?>

Attachment: PHP connects redis database singleton class

<?php
class RedisConnect
{
  /**
   * Redis的ip
   *
   * @var string
   */
  const REDISHOSTNAME = "127.0.0.1";
  /**
   * Redis的port
   *
   * @var int
   */
  const REDISPORT = 6379;
  /**
   * Redis的超时时间
   *
   * @var int
   */
  const REDISTIMEOUT = 0;
  /**
   * Redis的password
   *
   * @var unknown_type
   */
  const REDISPASSWORD = "ehualu";
  /**
   * Redis的DBname
   *
   * @var int
   */
  const REDISDBNAME = 12;
  /**
   * 类单例
   *
   * @var object
   */
  private static $instance;
  /**
   * Redis的连接句柄
   *
   * @var object
   */
  private $redis;
  /**
   * 私有化构造函数,防止类外实例化
   *
   * @param unknown_type $dbnumber
   */
  private function __construct ()
  {
    // 链接数据库
    $this->redis = new Redis();
    $this->redis->connect(self::REDISHOSTNAME, self::REDISPORT, self::REDISTIMEOUT);
    $this->redis->auth(self::REDISPASSWORD);
    $this->redis->select(self::REDISDBNAME);
  }
  /**
   * 私有化克隆函数,防止类外克隆对象
   */
  private function __clone ()
  {}
  /**
   * 类的唯一公开静态方法,获取类单例的唯一入口
   *
   * @return object
   */
  public static function getRedisInstance ()
  {
    if (! (self::$instance instanceof self)) {
      self::$instance = new self();
    }
    return self::$instance;
  }
  /**
   * 获取redis的连接实例
   *
   * @return Redis
   */
  public function getRedisConn ()
  {
    return $this->redis;
  }
  /**
   * 需要在单例切换的时候做清理工作
   */
  public function __destruct ()
  {
    self::$instance->redis->close();
    self::$instance = NULL;
  }
}
?>

Related recommendations:

Summary of usage of Redis function in PHP

The above is the detailed content of How to use Redis function in PHP. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn