Home Backend Development PHP Tutorial Common methods for operating Redis database with PHP

Common methods for operating Redis database with PHP

Nov 26, 2019 am 10:05 AM
php redis

Redis is an open source log-type Key-Value database written in ANSI C language, supports network, can be memory-based and persistent, and provides APIs in multiple languages.

The data types supported by Redis are Stirng (string), List (list), Hash (dictionary), Set (set), Sorted Set (ordered set);

Common methods for operating Redis database with PHP

In order for PHP to use redis, you must first install the redis extension.

1. Install redis

git download address

#2. Test redis

windows run (shortcut key: Windows key R key), enter the [cmd] command, Enter the DOC operating system window;

Enter the redis installation directory and use the command

2.1 Start the redis daemon (enter the redis installation directory)

redis-server.exe redis-windows-conf
Copy after login

2.2 Enter the redis client (enter redis Installation directory)

redis-cli.exe
Copy after login

3. Install the redis extension of php

Download address

Select the appropriate redis expansion compression package based on the phpinfo() information

4. Place the two files php_redis.dll and php_redis.pdb in the ext folder

5. Modify the php.ini file

extension=php_redis.dll
Copy after login

6. Verify Whether to enable the redis extension

View phpinfo() information, search for redis

7.php to connect and test the redis database (remember to enable the redis service)

New test.php

<?php
$redis = new Redis();
$redis->connect('127.0.0.1',6379); 
$redis->set('name','klc');
echo $redis->get('name');
?>
Copy after login

Operations on data types

Strng (string):

<?php
// 设置一个字符串的值
$redis->set('cat', 111);
//获取一个字符串的值
echo $redis->get('cat'); // 111
// 重复set
$redis->set('cat', 222);
echo $redis->get('cat'); // 222
Copy after login

List(List):

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


<?php
  //实例化redis
  $redis = new Redis();
  //连接
  $redis->connect('127.0.0.1', 6379);
  //列表
  //存储数据到列表中
  $redis->lpush('list', 'html');
  $redis->lpush('list', 'css');
  $redis->lpush('list', 'php');
  $redis->lpush('list', 'mysql');
  $redis->lpush('list', 'javascript');
  $redis->lpush('list', 'ajax');
  //获取列表中所有的值
  $list = $redis->lrange('list', 0, -1);
  print_r($list);echo '<br>'; 
  //获取列表的长度
  $length = $redis->lsize('list');
  echo $length;echo '<br>';
  //返回列表key中index位置的值
  echo $redis->lget('list', 2);echo '<br>';
  echo $redis->lindex('list', 2);echo '<br>';
  //设置列表中index位置的值
  echo $redis->lset('list', 2, 'linux');echo '<br>';
  $list = $redis->lrange('list', 0, -1);
  print_r($list);echo '<br>';
  //返回key中从start到end位置间的元素
  $list = $redis->lrange('list', 0, 2);
  print_r($list);echo '<br>';
  $list = $redis->lgetrange('list', 0, 2);
  print_r($list);echo '<br>';
  //截取链表中start到end的元素
//截取列表后列表发生变化,列表保留截取的元素,其余的删除
  $list = $redis->ltrim('list', 0, 1);
  print_r($list);echo '<br>';
  $list = $redis->lrange('list', 0, -1);
  print_r($list);echo '<br>';
  // 结果
  // Array ( [0] => ajax [1] => javascript [2] => mysql [3] => php [4] => css [5] => html )
  // 6
  // mysql
  // mysql
  // 1
  // Array ( [0] => ajax [1] => javascript [2] => linux [3] => php [4] => css [5] => html )
  // Array ( [0] => ajax [1] => javascript [2] => linux )
  // Array ( [0] => ajax [1] => javascript [2] => linux )
  // 1
  // Array ( [0] => ajax [1] => javascript )


<?php
  //实例化redis
  $redis = new Redis();
  //连接
  $redis->connect('127.0.0.1', 6379);
  //列表
  //存储数据到列表中
  $redis->lpush('list', 'html');
  $redis->lpush('list', 'html');
  $redis->lpush('list', 'html');
  $redis->lpush('list', 'css');
  $redis->lpush('list', 'php');
  $redis->lpush('list', 'mysql');
  $redis->lpush('list', 'javascript');
  $redis->lpush('list', 'html');
  $redis->lpush('list', 'html');
  $redis->lpush('list', 'html');
  $redis->lpush('list', 'ajax');
  //获取列表中所有的值
  $list = $redis->lrange('list', 0, -1);
  print_r($list);echo '<br>'; 
  //删除列表中count个值为value的元素
  //从左向右删
  $redis->lrem('list', 'html', 2);
  $list = $redis->lrange('list', 0, -1);
  print_r($list);echo '<br>'; 
  //从右向左删
  $redis->lrem('list', 'html', -2);
  $list = $redis->lrange('list', 0, -1);
  print_r($list);echo '<br>'; 
  //删除所有
  $redis->lrem('list', 'html', 0);
  $list = $redis->lrange('list', 0, -1);
  print_r($list);echo '<br>';
  // 结果
  // Array ( [0] => ajax [1] => html [2] => html [3] => html [4] => javascript [5] => mysql [6] => php [7] => css [8] => html [9] => html [10] => html )
  // Array ( [0] => ajax [1] => html [2] => javascript [3] => mysql [4] => php [5] => css [6] => html [7] => html [8] => html )
  // Array ( [0] => ajax [1] => html [2] => javascript [3] => mysql [4] => php [5] => css [6] => html )
  // Array ( [0] => ajax [1] => javascript [2] => mysql [3] => php [4] => css )
Copy after login

Hash(Dictionary):


<?php
  //实例化redis
  $redis = new Redis();
  //连接
  $redis->connect('127.0.0.1', 6379);
  //字典
  //给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>';
  //获取hash中某个key的值
  echo $redis->hget('hash', 'cat');echo '<br>';
  //获取hash中所有的keys
  $arr = $redis->hkeys('hash');
  print_r($arr);echo '<br>';
  //获取hash中所有的值 顺序是随机的
  $arr = $redis->hvals('hash');
  print_r($arr);echo '<br>';
  //获取一个hash中所有的key和value 顺序是随机的
  $arr = $redis->hgetall('hash');
  print_r($arr);echo '<br>';
  //获取hash中key的数量
  echo $redis->hlen('hash');echo '<br>';
  //删除hash中一个key 如果表不存在或key不存在则返回false
  echo $redis->hdel('hash', 'dog');echo '<br>';
  var_dump($redis->hdel('hash', 'rabbit'));echo '<br>';
  // 结果
  // 1
  // 0
  // 0
  // 1
  // 1
  // 1
  // cat1
  // Array ( [0] => cat [1] => dog [2] => bird [3] => monkey )
  // Array ( [0] => cat1 [1] => dog [2] => bird [3] => monkey )
  // Array ( [cat] => cat1 [dog] => dog [bird] => bird [monkey] => monkey )
  // 4
  // 1
  // int(0)
 

<?php
  //实例化redis
  $redis = new Redis();
  //连接
  $redis->connect('127.0.0.1', 6379);
  //字典
  //批量设置多个key的值
  $arr = [1=>1, 2=>2, 3=>3, 4=>4, 5=>5];
  $redis->hmset('hash', $arr);
  print_r($redis->hgetall('hash'));echo '<br>';
  // 批量获得额多个key的值
  $arr = [1, 2, 3, 5];
  $hash = $redis->hmget('hash', $arr);
  print_r($hash);echo '<br>';
  //检测hash中某个key知否存在
  echo $redis->hexists('hash', '1');echo '<br>';
  var_dump($redis->hexists('hash', 'cat'));echo '<br>';
  print_r($redis->hgetall('hash'));echo '<br>';
  //给hash表中key增加一个整数值
  $redis->hincrby('hash', '1', 1);
  print_r($redis->hgetall('hash'));echo '<br>';
  //给hash中的某个key增加一个浮点值
  $redis->hincrbyfloat('hash', 2, 1.3);
  print_r($redis->hgetall('hash'));echo '<br>';
  //结果
  // Array ( [1] => 1 [2] => 2 [3] => 3 [4] => 4 [5] => 5 )
  // Array ( [1] => 1 [2] => 2 [3] => 3 [5] => 5 )
  // 1
  // bool(false)
  // Array ( [1] => 1 [2] => 2 [3] => 3 [4] => 4 [5] => 5 )
  // Array ( [1] => 2 [2] => 2 [3] => 3 [4] => 4 [5] => 5 )
  // Array ( [1] => 2 [2] => 3.3 [3] => 3 [4] => 4 [5] => 5 )
Copy after login

Set( Set):


<?php
  //实例化redis
  $redis = new Redis();
  //连接
  $redis->connect('127.0.0.1', 6379);
  //集合
  // 添加一个元素
  echo $redis->sadd('set', 'cat');echo '<br>';
  echo $redis->sadd('set', 'cat');echo '<br>';
  echo $redis->sadd('set', 'dog');echo '<br>';
  echo $redis->sadd('set', 'rabbit');echo '<br>';
  echo $redis->sadd('set', 'bear');echo '<br>';
  echo $redis->sadd('set', 'horse');echo '<br>';
  // 查看集合中所有的元素
  $set = $redis->smembers('set');
  print_r($set);echo '<br>';
  //删除集合中的value
  echo $redis->srem('set', 'cat');echo '<br>';
  var_dump($redis->srem('set', 'bird'));echo '<br>';
  $set = $redis->smembers('set');
  print_r($set);echo '<br>';
  //判断元素是否是set的成员
  var_dump($redis->sismember('set', 'dog'));echo '<br>';
  var_dump($redis->sismember('set', 'bird'));echo '<br>';
  //查看集合中成员的数量
  echo $redis->scard('set');echo '<br>';
  //移除并返回集合中的一个随机元素(返回被移除的元素)
  echo $redis->spop('set');echo '<br>';
  print_r($redis->smembers('set'));echo '<br>';
  // 结果
  // 1
  // 0
  // 1
  // 1
  // 1
  // 1
  // Array ( [0] => rabbit [1] => cat [2] => bear [3] => dog [4] => horse )
  // 1
  // int(0)
  // Array ( [0] => dog [1] => rabbit [2] => horse [3] => bear )
  // bool(true)
  // bool(false)
  // 4
  // bear
  // Array ( [0] => dog [1] => rabbit [2] => horse )
Copy after login


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

Sorted Set:


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

Recommended study: "PHP Tutorial"

The above is the detailed content of Common methods for operating Redis database with PHP. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat Commands and How to Use Them
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

The Future of PHP: Adaptations and Innovations The Future of PHP: Adaptations and Innovations Apr 11, 2025 am 12:01 AM

The future of PHP will be achieved by adapting to new technology trends and introducing innovative features: 1) Adapting to cloud computing, containerization and microservice architectures, supporting Docker and Kubernetes; 2) introducing JIT compilers and enumeration types to improve performance and data processing efficiency; 3) Continuously optimize performance and promote best practices.

PHP vs. Python: Understanding the Differences PHP vs. Python: Understanding the Differences Apr 11, 2025 am 12:15 AM

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

How to build the redis cluster mode How to build the redis cluster mode Apr 10, 2025 pm 10:15 PM

Redis cluster mode deploys Redis instances to multiple servers through sharding, improving scalability and availability. The construction steps are as follows: Create odd Redis instances with different ports; Create 3 sentinel instances, monitor Redis instances and failover; configure sentinel configuration files, add monitoring Redis instance information and failover settings; configure Redis instance configuration files, enable cluster mode and specify the cluster information file path; create nodes.conf file, containing information of each Redis instance; start the cluster, execute the create command to create a cluster and specify the number of replicas; log in to the cluster to execute the CLUSTER INFO command to verify the cluster status; make

How to use the redis command How to use the redis command Apr 10, 2025 pm 08:45 PM

Using the Redis directive requires the following steps: Open the Redis client. Enter the command (verb key value). Provides the required parameters (varies from instruction to instruction). Press Enter to execute the command. Redis returns a response indicating the result of the operation (usually OK or -ERR).

PHP: Is It Dying or Simply Adapting? PHP: Is It Dying or Simply Adapting? Apr 11, 2025 am 12:13 AM

PHP is not dying, but constantly adapting and evolving. 1) PHP has undergone multiple version iterations since 1994 to adapt to new technology trends. 2) It is currently widely used in e-commerce, content management systems and other fields. 3) PHP8 introduces JIT compiler and other functions to improve performance and modernization. 4) Use OPcache and follow PSR-12 standards to optimize performance and code quality.

How to read the source code of redis How to read the source code of redis Apr 10, 2025 pm 08:27 PM

The best way to understand Redis source code is to go step by step: get familiar with the basics of Redis. Select a specific module or function as the starting point. Start with the entry point of the module or function and view the code line by line. View the code through the function call chain. Be familiar with the underlying data structures used by Redis. Identify the algorithm used by Redis.

How to clear redis data How to clear redis data Apr 10, 2025 pm 10:06 PM

How to clear Redis data: Use the FLUSHALL command to clear all key values. Use the FLUSHDB command to clear the key value of the currently selected database. Use SELECT to switch databases, and then use FLUSHDB to clear multiple databases. Use the DEL command to delete a specific key. Use the redis-cli tool to clear the data.

How to read redis queue How to read redis queue Apr 10, 2025 pm 10:12 PM

To read a queue from Redis, you need to get the queue name, read the elements using the LPOP command, and process the empty queue. The specific steps are as follows: Get the queue name: name it with the prefix of "queue:" such as "queue:my-queue". Use the LPOP command: Eject the element from the head of the queue and return its value, such as LPOP queue:my-queue. Processing empty queues: If the queue is empty, LPOP returns nil, and you can check whether the queue exists before reading the element.

See all articles