redis 的连接

描述:实例连接到一个Redis.

参数:host: string,port: int

返回值:BOOL 成功返回:TRUE;失败返回:FALSE

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

redis 操作 Strng (字符串)

set、get 、delete

$redis = new Redis();
$result = $redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
$redis->set('name', 'jackie');//设置key和value的值
echo $redis->get('name') . "<br/>";//获取有关指定键的值 $redis->delete('name');//删除指定的键
var_dump($redis->get('name')); //结果:bool(false)

setnx

描述:如果在数据库中不存在该键,设置关键值参数

参数:key value

返回值:BOOL 成功返回:TRUE;失败返回:FALSE

$redis = new Redis();
$result = $redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
$redis->set('name', 'jackie');
$redis->setnx('name', 'louis');
echo $redis->get('name') . "<br/>";//jackie $redis->delete('name');
$redis->setnx('name', 'louis');
echo $redis->get('name');//louis

exists

描述:验证指定的键是否存在

$redis = new Redis();
$result = $redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
$redis->set('test',"1111111111111");
var_dump($redis->exists('test')); //结果:bool(true)

incr

描述:数字递增存储键值键.

$redis = new Redis();
$result = $redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
$redis->set('test', "123");
var_dump($redis->incr("test")); //结果:int(124)
var_dump($redis->incr("test")); //结果:int(125)

decr

描述:数字递减存储键值。

$redis = new Redis();
$result = $redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
$redis->set('test', "123");
var_dump($redis->decr("test")); //结果:int(122)
var_dump($redis->decr("test")); //结果:int(121)

getMultiple

描述:取得所有指定键的值。如果一个或多个键不存在,该数组中该键的值为假

参数:其中包含键值的列表数组

返回值:返回包含所有键的值的数组

$redis = new Redis();
$result = $redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
$redis->set('test1',"1");
$redis->set('test2',"2");
$result = $redis->getMultiple(array('test1','test2'));
print_r($result); //结果:Array ( [0] => 1 [1] => 2 )

redis 操作 List (列表)

lpush、rpush、lpop、rpop

<?php
$redis = new Redis();
$result = $redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
$redis->delete('list');
//存储数据到列表中
$redis->lpush('list', 'html');
$redis->lpush('list', 'css');
$redis->lpush('list', 'php');
//获取列表中所有的值
$list = $redis->lrange('list', 0, -1);
print_r($list);echo '<br>';
// Array ( [0] => php [1] => css [2] => html )
//从右侧加入一个
$redis->rpush('list', 'mysql');
$list = $redis->lrange('list', 0, -1);
print_r($list);echo '<br>';
// Array ( [0] => php [1] => css [2] => html [3] => mysql )
//从左侧弹出一个
$redis->lpop('list');
$list = $redis->lrange('list', 0, -1);
print_r($list);echo '<br>';
// Array ( [0] => css [1] => html [2] => mysql )
//从右侧弹出一个
$redis->rpop('list');
$list = $redis->lrange('list', 0, -1);
print_r($list);echo '<br>';
// Array ( [0] => css [1] => html )

redis 操作 Hash (字典)

hset、hget、 hkeys、 hvals、 hgetall、 hlen、 hdel

<?php
$redis = new Redis();
$result = $redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
//字典
//给hash表中某个key设置value
//如果没有则设置成功,返回1,如果存在会替换原有的值,返回0,失败返回0
echo $redis->hset('hash', 'cat', 'cat');echo '<br>'; //
echo $redis->hset('hash', 'cat', 'cat');echo '<br>'; //
echo $redis->hset('hash', 'cat', 'cat1');echo '<br>'; //
echo $redis->hset('hash', 'dog', 'dog');echo '<br>'; //
echo $redis->hset('hash', 'bird', 'bird');echo '<br>'; //
echo $redis->hset('hash', 'monkey', 'monkey');echo '<br>'; // 1
//获取hash中某个key的值
echo $redis->hget('hash', 'cat');echo '<br>'; // cat1
//获取hash中所有的keys
$arr = $redis->hkeys('hash');
print_r($arr);echo '<br>';
// Array ( [0] => cat [1] => dog [2] => bird [3] => monkey )
//获取hash中所有的值 顺序是随机的
$arr = $redis->hvals('hash');
print_r($arr);echo '<br>';
// Array ( [0] => cat1 [1] => dog [2] => bird [3] => monkey )
//获取一个hash中所有的key和value 顺序是随机的
$arr = $redis->hgetall('hash');
print_r($arr);echo '<br>';
// Array ( [cat] => cat1 [dog] => dog [bird] => bird [monkey] => monkey )
//获取hash中key的数量
echo $redis->hlen('hash');echo '<br>';
// 4
//删除hash中一个key 如果表不存在或key不存在则返回false
echo $redis->hdel('hash', 'dog');echo '<br>';
var_dump($redis->hdel('hash', 'rabbit'));echo '<br>';
// 1
// int(0)

 redis 操作 Set (集合)

sadd、smembers 

<?php
//实例化redis
$redis = new Redis();
//连接
$redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
//集合
$redis->sadd('set', 'horse');
$redis->sadd('set', 'cat');
$redis->sadd('set', 'dog');
$redis->sadd('set', 'bird');
$redis->sadd('set2', 'fish');
$redis->sadd('set2', 'dog');
$redis->sadd('set2', 'bird');
print_r($redis->smembers('set'));echo '<br>';
// Array ( [0] => cat [1] => dog [2] => bird [3] => horse )
print_r($redis->smembers('set2'));echo '<br>';
// Array ( [0] => bird [1] => dog [2] => fish )
//返回集合的交集
print_r($redis->sinter('set', 'set2'));echo '<br>';
// Array ( [0] => dog [1] => bird )
//执行交集操作 并结果放到一个集合中
$redis->sinterstore('output', 'set', 'set2');
print_r($redis->smembers('output'));echo '<br>';
// Array ( [0] => dog [1] => bird )
//返回集合的并集
print_r($redis->sunion('set', 'set2'));echo '<br>';
// Array ( [0] => cat [1] => dog [2] => bird [3] => horse [4] => fish )
//执行并集操作 并结果放到一个集合中
$redis->sunionstore('output', 'set', 'set2');
print_r($redis->smembers('output'));echo '<br>';
// Array ( [0] => cat [1] => dog [2] => bird [3] => horse [4] => fish )
//返回集合的差集
print_r($redis->sdiff('set', 'set2'));echo '<br>';
// Array ( [0] => horse [1] => cat )
//执行差集操作 并结果放到一个集合中
$redis->sdiffstore('output', 'set', 'set2');
print_r($redis->smembers('output'));echo '<br>';
// Array ( [0] => horse [1] => cat )

 redis 操作 Sorted Set (有序集合)

zadd、zrange

<?php
//实例化redis
$redis = new Redis();
//连接
$redis->connect('127.0.0.1', 6379);
$redis->auth('123456');
//有序集合
//添加元素 分数
echo $redis->zadd('zset', 1, 'cat');echo '<br>'; //
echo $redis->zadd('zset', 2, 'dog');echo '<br>'; //
echo $redis->zadd('zset', 3, 'fish');echo '<br>'; //
echo $redis->zadd('zset', 4, 'dog');echo '<br>'; //
echo $redis->zadd('zset', 4, 'bird');echo '<br>'; // 1
//返回集合中的所有元素
print_r($redis->zrange('zset', 0, -1));echo '<br>';
// Array ( [0] => cat [1] => fish [2] => bird [3] => dog )
print_r($redis->zrange('zset', 0, -1, true));echo '<br>';
// Array ( [cat] => 1 [fish] => 3 [bird] => 4 [dog] => 4 )
//返回元素的score值
echo $redis->zscore('zset', 'dog');echo '<br>';
// 4
//返回存储的个数
echo $redis->zcard('zset');echo '<br>';
// 4
//删除指定成员
$redis->zrem('zset', 'cat');
print_r($redis->zrange('zset', 0, -1));echo '<br>';
// Array ( [0] => fish [1] => bird [2] => dog )
//返回集合中介于min和max之间的值的个数
print_r($redis->zcount('zset', 3, 5));echo '<br>';
// 3
//返回有序集合中score介于min和max之间的值
print_r($redis->zrangebyscore('zset', 3, 5));echo '<br>';
// Array ( [0] => fish [1] => bird [2] => dog )
print_r($redis->zrangebyscore('zset', 3, 5, ['withscores'=>true]));echo '<br>';
// Array ( [fish] => 3 [bird] => 4 [dog] => 4 )
//返回集合中指定区间内所有的值 倒叙
print_r($redis->zrevrange('zset', 1, 2));echo '<br>';
// Array ( [0] => bird [1] => fish )
print_r($redis->zrevrange('zset', 1, 2, true));echo '<br>';
// Array ( [bird] => 4 [fish] => 3 )
//有序集合中指定值的socre增加
echo $redis->zscore('zset', 'dog');echo '<br>';
//
$redis->zincrby('zset', 2, 'dog');
echo $redis->zscore('zset', 'dog');echo '<br>';
// 6
//移除score值介于min和max之间的元素
print_r($redis->zrange('zset', 0, -1, true));echo '<br>';
// Array ( [fish] => 3 [bird] => 4 [dog] => 6 )
print_r($redis->zremrangebyscore('zset', 3, 4));echo '<br>';
//
print_r($redis->zrange('zset', 0, -1, true));echo '<br>';
// Array ( [dog] => 6 )

参考

PHP操作Redis的基本方法总结: https://mp.weixin.qq.com/s/SNMNfJorEHC8if411F8-aw

php操作redis常用方法代码示例的更多相关文章

  1. 30个php操作redis常用方法代码例子

    From: http://www.jb51.net/article/51884.htm 这篇文章主要介绍了30个php操作redis常用方法代码例子,本文其实不止30个方法,可以操作string类型. ...

  2. 30 个 php 操作 redis 常用方法代码例子

    这篇文章主要介绍了 30 个 php 操作 redis 常用方法代码例子 , 本文其实不止 30 个方法 , 可以操作 string 类型. list 类型和 set 类型的数据 , 需要的朋友可以参 ...

  3. 爱漂泊人生 30个php操作redis常用方法代码例子

    http://www.justwinit.cn/post/8789/ 背景:redis这个新产品在sns时很火,而memcache早就存在, 但redis提供出来的功能,好多网站均把它当memcach ...

  4. 30个php操作redis常用方法代码例子【转】

    背景:redis这个新产品在sns时很火,而memcache早就存在, 但redis提供出来的功能,好多网站均把它当memcache使用,这是大才小用,这儿有30个方法来使用redis,值得了解. 这 ...

  5. 30个php操作redis常用方法代码例子(转载)

    1.connect 描述:实例连接到一个Redis.参数:host: string,port: int返回值:BOOL 成功返回:TRUE;失败返回:FALSE示例: $redis = new red ...

  6. SELECT控件操作的JS代码示例

    SELECT控件操作的JS代码示例 1 检测是否有选中 if(objSelect.selectedIndex > -1) { //说明选中 } else { //说明没有选中 } 2.动态创建s ...

  7. Python 操作redis 常用方法

    Python 操作redis 1.字符串 #!/usr/bin/env python # -*- coding:utf-8 -*- import redis # python 操作str class ...

  8. 使用jedis操作redis常用方法

    在redis入门及在商城案例中的使用中简单介绍了下使用jedis如何操作redis,但是其实方法是跟redis的操作大部分是相对应的.我这里做下记录 1.String类型操作 public class ...

  9. php redis常用方法代码例子

    1,connect 描述:实例连接到一个Redis.参数:host: string,port: int返回值:BOOL 成功返回:TRUE;失败返回:FALSE 示例: <?php $redis ...

随机推荐

  1. python将文件导入字典

    a={}i=0f = open("filepath","r")for line in f.readlines(): a[i] =line i=i+1 a是字典, ...

  2. String、StringBuffer、StringBuilder详解

    String类 字符串广泛应用在java编程中,String类在java.lang包中,String类是final修饰的,不能被继承,String类对象创建后不能修改,由0或多个字符组成,包含在一对双 ...

  3. Quartz.Net 任务调度之时间策略(4)

    在复杂的业务逻辑中,cron可以灵活的制定时间策略 先说使用方法 ITrigger trigger = TriggerBuilder.Create() .WithIdentity("trig ...

  4. 【JVM】吞吐量与延迟关系

    堆内存增大,gc一次能处理的数量变大,吞吐量大:但是gc一次的时间会变长,导致后面排队的线程等待时间变长: 向反,如果堆内存小,gc一次时间短,排队等待的线程等待时间变短,延迟减少,但一次请求的数量变 ...

  5. 如何通过Dataphin构建数据中台新增100万用户?

    欢迎来到数据中台小讲堂!这一期我们来看看,作为阿里巴巴数据中台(OneData - OneModel.OneID.OneService)方法论的产品载体,Dataphin如何帮助传统零售企业实现数字化 ...

  6. 第一次用angularJS做后台管理点滴

    很早以前就大概看过一点angualrjs,但是没有项目,一直没有进行下去,就是干巴巴的看着,过了一段时间发现什么也不记得了. 来yulebaby我的第一个后台管理是用easyui做的,做完那个以后发现 ...

  7. NOIp 图论算法专题总结 (2)

    系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 树链剖分 https://oi-wiki.org/graph/heavy-lig ...

  8. jdk8的stream流式计算的操作

    jdk8之后增加了流式计算,现在根据学习了流式计算,并把过程记录下来: Person.java的bean package com.zhang.collectordemo; /** * @program ...

  9. Ubuntu配置jdk环境变量

    下载jdk,解压到你想要的目录 在/etc/profile里最后添加 export JAVA_HOME=/home/zzs0/Programs/jdk1.8.0_102export JRE_HOME= ...

  10. Java牛角尖【007】:Java中的Error能不能被Catch

      Java牛角尖[007]:Java中的Error能不能被Catch 网上看到很多朋友说Java中Error是无法Catch到的,而Java中定义的Error类型又很难测试到,那就估且以为确是如此吧 ...