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

最新文章

  1. 兼容javascript和C#的RSA加密解密算法,对web提交的数据进行加密传输
  2. sublime text3的一些插件安装方法和使用
  3. python字符串的编码格式
  4. 【笔记】memorymanagement-whitepaper-150215
  5. 使用Html5+C#+微信 开发移动端游戏详细教程: (四)游戏中层的概念与设计
  6. mamp pro
  7. 【Java】String,StringBuffer与StringBuilder的区别??
  8. [转] linux系统文件流、文件描述符与进程间关系详解
  9. ***1133. Fibonacci Sequence(斐波那契数列,二分,数论)
  10. Java-NIO(九):管道 (Pipe)
  11. poj 3090 Visible Lattice Points(离线打表)
  12. C++隐藏任务栏图标
  13. Visual Stuido Online:如何禁止多人同时签出同一文件
  14. ogg BR – BOUNDED RECOVERY 测试案例
  15. LOADING Redis is loading the dataset in memory Redis javaAPI实例
  16. Confluence 6 导入一个文本文件
  17. C#设计模式(8)——桥接模式(Bridge Pattern)(转)
  18. scrapy selenium 登陆zhihu
  19. angular2.0 官网架构文档
  20. com.android.dx.command.Main with arguments

热门文章

  1. 12.整合neo4j
  2. 4412 i2c驱动
  3. PCB学习
  4. Python基础教程(018)--官方解释器交互运行
  5. basic play
  6. 【靶场练习_upload-labs复现】Pass01-020
  7. [BZOJ1572] WorkScheduling
  8. [CSP-S模拟测试]:english(可持久化Trie+启发式合并)
  9. LintCode之删除排序链表中的重复元素
  10. Linux系统结构 详解