redis在php中使用的常用命令

<?php

/*1.Connection*/

  $redis = new Redis();

  $redis->connect(‘127.0.0.1‘,6379,1);//短链接,本地host,端口为6379,超过1秒放弃链接

  $redis->open(‘127.0.0.1‘,6379,1);//短链接(同上)

  $redis->pconnect(‘127.0.0.1‘,6379,1);//长链接,本地host,端口为6379,超过1秒放弃链接

  $redis->popen(‘127.0.0.1‘,6379,1);//长链接(同上)

  $redis->auth(‘password‘);//登录验证密码,返回【true | false】

  $redis->select(0);//选择redis库,0~15 共16个库

  $redis->close();//释放资源

  $redis->ping(); //检查是否还再链接,[+pong]

  $redis->ttl(‘key‘);//查看失效时间[-1 | timestamps]

  $redis->persist(‘key‘);//移除失效时间[ 1 | 0]

  $redis->sort(‘key‘,[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素,$array为参数limit等!【配合$array很强大】 [array|false]

/*2.共性的运算归类*/

  $redis->expire(‘key‘,10);//设置失效时间[true | false]

  $redis->move(‘key‘,15);//把当前库中的key移动到15库中[0|1]

//string

  $redis->strlen(‘key‘);//获取当前key的长度

  $redis->append(‘key‘,‘string‘);//把string追加到key现有的value中[追加后的个数]

  $redis->incr(‘key‘);//自增1,如不存在key,赋值为1(只对整数有效,存储以10进制64位,redis中为str)[new_num | false]

  $redis->incrby(‘key‘,$num);//自增$num,不存在为赋值,值需为整数[new_num | false]

  $redis->decr(‘key‘);//自减1,[new_num | false]

  $redis->decrby(‘key‘,$num);//自减$num,[ new_num | false]

  $redis->setex(‘key‘,10,‘value‘);//key=value,有效期为10秒[true]

//list

  $redis->llen(‘key‘);//返回列表key的长度,不存在key返回0, [ len | 0]

//set

  $redis->scard(‘key‘);//返回集合key的基数(集合中元素的数量)。[num | 0]

  $redis->sMove(‘key1‘, ‘key2‘, ‘member‘);//移动,将member元素从key1集合移动到key2集合。[1 | 0]

//Zset

  $redis->zcard(‘key‘);//返回集合key的基数(集合中元素的数量)。[num | 0]

  $redis->zcount(‘key‘,0,-1);//返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]

//hash

  $redis->hexists(‘key‘,‘field‘);//查看hash中是否存在field,[1 | 0]

  $redis->hincrby(‘key‘,‘field‘,$int_num);//为哈希表key中的域field的值加上量(+|-)num,[new_num | false]

  $redis->hlen(‘key‘);//返回哈希表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(‘key‘,‘keyn‘);//监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 [true]

  $redis->unwatch(‘key‘,‘keyn‘);//取消监视一个(或多个) key [true]

  $redis->multi(Redis::MULTI);//开启事务,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。

  $redis->multi(Redis::PIPELINE);//开启管道,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。

  $redis->exec();//执行所有事务块内的命令,;【事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值 false】

/*4.String,键值对,创建更新同操作*/

  $redis->setOption(Redis::OPT_PREFIX,‘hf_‘);//设置表前缀为hf_

  $redis->set(‘key‘,1);//设置key=aa value=1 [true]

  $redis->mset($arr);//设置一个或多个键值[true]

  $redis->setnx(‘key‘,‘value‘);//key=value,key存在返回false[|true]

  $redis->get(‘key‘);//获取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(‘old_key‘,‘new_value‘);//先获得key的值,然后重新赋值,[old_value | false]

/*5.List栈的结构,注意表头表尾,创建更新分开操作*/

  $redis->lpush(‘key‘,‘value‘);//增,只能将一个值value插入到列表key的表头,不存在就创建 [列表的长度 |false]

  $redis->rpush(‘key‘,‘value‘);//增,只能将一个值value插入到列表key的表尾 [列表的长度 |false]

  $redis->lInsert(‘key‘, Redis::AFTER, ‘value‘, ‘new_value‘);//增,将值value插入到列表key当中,位于值value之前或之后。[new_len | false]

  $redis->lpushx(‘key‘,‘value‘);//增,只能将一个值value插入到列表key的表头,不存在不创建 [列表的长度 |false]

  $redis->rpushx(‘key‘,‘value‘);//增,只能将一个值value插入到列表key的表尾,不存在不创建 [列表的长度 |false]

  $redis->lpop(‘key‘);//删,移除并返回列表key的头元素,[被删元素 | false]

  $redis->rpop(‘key‘);//删,移除并返回列表key的尾元素,[被删元素 | false]

  $redis->lrem(‘key‘,‘value‘,0);//删,根据参数count的值,移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value) [被移除的数量 | 0]

  $redis->ltrim(‘key‘,start,end);//删,列表修剪,保留(start,end)之间的值 [true|false]

  $redis->lset(‘key‘,index,‘new_v‘);//改,从表头数,将列表key下标为第index的元素的值为new_v, [true | false]

  $redis->lindex(‘key‘,index);//查,返回列表key中,下标为index的元素[value|false]

  $redis->lrange(‘key‘,0,-1);//查,(start,stop|0,-1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。[array|false]

/*6.Set,没有重复的member,创建更新同操作*/

  $redis->sadd(‘key‘,‘value1‘,‘value2‘,‘valuen‘);//增,改,将一个或多个member元素加入到集合key当中,已经存在于集合的member元素将被忽略。[insert_num]

  $redis->srem(‘key‘,‘value1‘,‘value2‘,‘valuen‘);//删,移除集合key中的一个或多个member元素,不存在的member元素会被忽略 [del_num | false]

  $redis->smembers(‘key‘);//查,返回集合key中的所有成员 [array | ‘‘]

  $redis->sismember(‘key‘,‘member‘);//判断member元素是否是集合key的成员 [1 | 0]

  $redis->spop(‘key‘);//删,移除并返回集合中的一个随机元素 [member | false]

  $redis->srandmember(‘key‘);//查,返回集合中的一个随机元素 [member | false]

  $redis->sinter(‘key1‘,‘key2‘,‘keyn‘);//查,返回所有给定集合的交集 [array | false]

  $redis->sunion(‘key1‘,‘key2‘,‘keyn‘);//查,返回所有给定集合的并集 [array | false]

  $redis->sdiff(‘key1‘,‘key2‘,‘keyn‘);//查,返回所有给定集合的差集 [array | false]

/*7.Zset,没有重复的member,有排序顺序,创建更新同操作*/

  $redis->zAdd(‘key‘,$score1,$member1,$scoreN,$memberN);//增,改,将一个或多个member元素及其score值加入到有序集key当中。[num | 0]

  $redis->zrem(‘key‘,‘member1‘,‘membern‘);//删,移除有序集key中的一个或多个成员,不存在的成员将被忽略。[del_num | 0]

  $redis->zscore(‘key‘,‘member‘);//查,通过值反拿权 [num | null]

  $redis->zrange(‘key‘,$start,$stop);//查,通过(score从小到大)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]

  $redis->zrevrange(‘key‘,$start,$stop);//查,通过(score从大到小)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]

  $redis->zrangebyscore(‘key‘,$min,$max[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从小到大排)成员[array | null]

  $redis->zrevrangebyscore(‘key‘,$max,$min[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从大到小排)成员[array | null]

  $redis->zrank(‘key‘,‘member‘);//查,通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]

  $redis->zrevrank(‘key‘,‘member‘);//查,通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]

  $redis->ZINTERSTORE();//交集

  $redis->ZUNIONSTORE();//差集

/*8.Hash,表结构,创建更新同操作*/

  $redis->hset(‘key‘,‘field‘,‘value‘);//增,改,将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】

  $redis->hget(‘key‘,‘field‘);//查,取值【value|false】

  $arr = array(‘one‘=>1,2,3);$arr2 = array(‘one‘,0,1);

  $redis->hmset(‘key‘,$arr);//增,改,设置多值$arr为(索引|关联)数组,$arr[key]=field, [ true ]

  $redis->hmget(‘key‘,$arr2);//查,获取指定下标的field,[$arr | false]

  $redis->hgetall(‘key‘);//查,返回哈希表key中的所有域和值。[当key不存在时,返回一个空表]

  $redis->hkeys(‘key‘);//查,返回哈希表key中的所有域。[当key不存在时,返回一个空表]

  $redis->hvals(‘key‘);//查,返回哈希表key中的所有值。[当key不存在时,返回一个空表]

  $redis->hdel(‘key‘,$arr2);//删,删除指定下标的field,不存在的域将被忽略,[num | false]

?>

附:php 连接redis 数据库单例类


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

<?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;

  }

}

?>

原文地址:https://www.cnblogs.com/wzg-bky/p/11634468.html

时间: 2024-10-18 06:27:35

redis在php中使用的常用命令的相关文章

[转帖]「日常小记」linux中强大且常用命令:find、grep

「日常小记」linux中强大且常用命令:find.grep https://zhuanlan.zhihu.com/p/74379265 在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍find.grep命令,他哥俩可以算是必会的linux命令,我几乎每天都要用到他们.本文结构如下: find命令 find命令的一般形式 find命令的常用选项及实例 find与xargs grep命令 grep命令的一般形式 grep正则表达式元字符集(基本集) grep命令的常用选项及实例 1.

Redis系列(二):Redis的5种数据结构及其常用命令

上一篇博客,我们讲解了什么是Redis以及在Windows和Linux环境下安装Redis的方法, 没看过的同学可以点击以下链接查看: Redis系列(一):Redis简介及环境安装. 本篇博客我们来讲解下Redis的5种数据结构及其常用命令,5种数据结构分别为: 字符串String 列表List 集合Set 散列Hash 有序集合ZSet 注意事项:Redis可以存储键(key)值(value)对的映射,其中键(key)一直是String,而值可以是上面提到的5种数据结构中的一种. 1. 字符

Redis的5种数据结构及其常用命令

本篇博客我们来讲解下Redis的5种数据结构及其常用命令,5种数据结构分别为: 字符串String 列表List 集合Set 散列Hash 有序集合ZSet 注意事项:Redis可以存储键(key)值(value)对的映射,其中键(key)一直是String,而值可以是上面提到的5种数据结构中的一种. 1. 字符串String 在Redis中,字符串可以存储以下3种类型的值: 字节串(byte string) 整数 浮点数 经常使用的字符串命令主要分为以下3种类型: 常用命令 自增自减命令 子串

Redis学习笔记(三)常用命令整理

Redis 常用命令 1.DEL key 删除key2.EXISTS key 检查key是否存在3.KEYS * 查看所有的key4.EXPIRE key seconds 设置key的过期时间5.TTL key 返回key的剩余生存时间6.TYPE key 返回key的类型 String 常用 1.SET key value 设置指定key的值2.GET key 获取指定key的值3.GETRANGE key start end 返回key start到end位置的字符4.STRLEN key

Linux中git的常用命令

1.安装依赖包 sudo yum install curl-devel expat-devel gettext-developenssl-devel zlib-devel sudo yum install libcurl4-gnutls-dev libexpat1-dev gettext libz-dev libssl-dev 2.安装git yum -y install git 3.创建项目目录 mkdir gitbase cd gitbase 4.创建共享库 sudo git init 5.

NoSQL -- redis 安装 主从 配置详解 常用命令

Redis 也是key-value存储系统,官方站点 http://redis.io,但相对于memcache,有如下优势: 1.支持更多地value类型(string.hash.lists.sets.sorted sets等): 2.支持数据持久化,预防服务重启后需要重新存储: redis 有两种文件格式:全量数据(RDB=redis database).增量请求(aof=append only file). 前者是将内存中的数据写进磁盘,便于下次读取文件时直接进行加载,快照形式: 后者是将r

Rabbitmq中rabbitmqctl的常用命令

学习rabbitmq,原理之后第一个要掌握的就是rabbitmqctl这个命令的用法了,rabbitmq的管理功能最全的就是rabbitmqctl命令了,当然还有HTTP API和UI两种管理手段. rabbitmqctl的使用方法: rabbitmqctl [-n <node>] [-q] <command> [<command options>] -n node 默认node名称是"[email protected]",如果你的主机明是'serv

Linux中vi编辑器常用命令

游标控制 h 游标向左移 j 游标向下移 k 游标向上移 l (or spacebar) 游标向右移 w 向前移动一个单词 b 向后移动一个单词 e 向前移动一个单词,且游标指向单词的末尾 ( 移到当前句子的首部 ) 移到下一个句子的首部 { 移到当前段的首部 } 移到下一段的首部 [[ 移到当前区段的首部 ]] 移到下一个区段的首部 0 移到当前行的首部 $ 移到当前行的尾部 ^ 移到当前行第一个非空白字符的地方 + or RETURN 移动到下一行的第一个字符 - 移动到上一行的第一个字符

在linux中如何查看常用命令的源码

Linux中有很多很棒的工具,我们可以在平常的使用中,可以采用查看源码的方式来学习它.以下就以uptime为例来说一说吧. 1.首先,我们要查询一下uptime是由哪个package提供的 #rpm -qf $(which uptime) procps-3.2.8-33.0.1.el6.x86_64 2.接着,我们要来下载带源码的rpm包了,在确保你的OS能连接外网并配置好yum源后,就可以用下面的命令来完成了. yumdownloader --source procps 3.解压 rpm -i