使用PHP要如何操作Redis?基本操作方法介绍
使用PHP要如何操作Redis?下面本篇文章给大家分享一些PHP操作Redis的基本方法,例如redis连接、操作Strng、List、Hash、Set等等,希望对大家有所帮助。
最近系统性的研究了下 redis,准备些一篇 redis 使用常遇到的问题;包括:
redis 的基本操作方法
1 redis 的连接 :
//实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //检测是否连接成功 echo "Server is running: " . $redis->ping(); // 输出结果 Server is running: +PONG
2 redis 操作 Strng (字符串):
// 设置一个字符串的值 $redis->set('cat', 111); //获取一个字符串的值 echo $redis->get('cat'); // 111 // 重复set $redis->set('cat', 222); echo $redis->get('cat'); // 222
3 redis 操作 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 )
4 redis 操作 Hash (字典):
<?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>'; // 1 echo $redis->hset('hash', 'cat', 'cat');echo '<br>'; // 0 echo $redis->hset('hash', 'cat', 'cat1');echo '<br>'; // 0 echo $redis->hset('hash', 'dog', 'dog');echo '<br>'; // 1 echo $redis->hset('hash', 'bird', 'bird');echo '<br>'; // 1 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)
5 redis 操作 Set (集合):
<?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //集合 // 添加一个元素 echo $redis->sadd('set', 'cat');echo '<br>'; // 1 echo $redis->sadd('set', 'cat');echo '<br>'; // 0 echo $redis->sadd('set', 'dog');echo '<br>'; // 1 echo $redis->sadd('set', 'rabbit');echo '<br>'; // 1 echo $redis->sadd('set', 'bear');echo '<br>'; // 1 echo $redis->sadd('set', 'horse');echo '<br>'; // 1 // 查看集合中所有的元素 $set = $redis->smembers('set'); print_r($set);echo '<br>'; // Array ( [0] => rabbit [1] => cat [2] => bear [3] => dog [4] => horse ) //删除集合中的value echo $redis->srem('set', 'cat');echo '<br>'; // 1 var_dump($redis->srem('set', 'bird'));echo '<br>'; // int(0) $set = $redis->smembers('set'); print_r($set);echo '<br>'; // Array ( [0] => dog [1] => rabbit [2] => horse [3] => bear ) //判断元素是否是set的成员 var_dump($redis->sismember('set', 'dog'));echo '<br>'; // bool(true) var_dump($redis->sismember('set', 'bird'));echo '<br>'; // bool(false) //查看集合中成员的数量 echo $redis->scard('set');echo '<br>'; // 4 //移除并返回集合中的一个随机元素(返回被移除的元素) echo $redis->spop('set');echo '<br>'; // bear print_r($redis->smembers('set'));echo '<br>'; // Array ( [0] => dog [1] => rabbit [2] => horse ) <?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>'; // 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 )
6 redis 操作 Sorted Set (有序集合):
<?php //实例化redis $redis = new Redis(); //连接 $redis->connect('127.0.0.1', 6379); //有序集合 //添加元素 分数 echo $redis->zadd('set', 1, 'cat');echo '<br>'; // 1 echo $redis->zadd('set', 2, 'dog');echo '<br>'; // 1 echo $redis->zadd('set', 3, 'fish');echo '<br>'; // 1 echo $redis->zadd('set', 4, 'dog');echo '<br>'; // 0 echo $redis->zadd('set', 4, 'bird');echo '<br>'; // 1 //返回集合中的所有元素 print_r($redis->zrange('set', 0, -1));echo '<br>'; // Array ( [0] => cat [1] => fish [2] => bird [3] => dog ) print_r($redis->zrange('set', 0, -1, true));echo '<br>'; // Array ( [cat] => 1 [fish] => 3 [bird] => 4 [dog] => 4 ) //返回元素的score值 echo $redis->zscore('set', 'dog');echo '<br>'; // 4 //返回存储的个数 echo $redis->zcard('set');echo '<br>'; // 4 //删除指定成员 $redis->zrem('set', 'cat'); print_r($redis->zrange('set', 0, -1));echo '<br>'; // Array ( [0] => fish [1] => bird [2] => dog ) //返回集合中介于min和max之间的值的个数 print_r($redis->zcount('set', 3, 5));echo '<br>'; // 3 //返回有序集合中score介于min和max之间的值 print_r($redis->zrangebyscore('set', 3, 5));echo '<br>'; // Array ( [0] => fish [1] => bird [2] => dog ) print_r($redis->zrangebyscore('set', 3, 5, ['withscores'=>true]));echo '<br>'; // Array ( [fish] => 3 [bird] => 4 [dog] => 4 ) //返回集合中指定区间内所有的值 倒叙 print_r($redis->zrevrange('set', 1, 2));echo '<br>'; // Array ( [0] => bird [1] => fish ) print_r($redis->zrevrange('set', 1, 2, true));echo '<br>'; // Array ( [bird] => 4 [fish] => 3 ) //有序集合中指定值的socre增加 echo $redis->zscore('set', 'dog');echo '<br>'; // 4 $redis->zincrby('set', 2, 'dog'); echo $redis->zscore('set', 'dog');echo '<br>'; // 6 //移除score值介于min和max之间的元素 print_r($redis->zrange('set', 0, -1, true));echo '<br>'; // Array ( [fish] => 3 [bird] => 4 [dog] => 6 ) print_r($redis->zremrangebyscore('set', 3, 4));echo '<br>'; // 2 print_r($redis->zrange('set', 0, -1, true));echo '<br>'; // Array ( [dog] => 6 ) //结果
更多编程相关知识,请访问:编程视频!!
Atas ialah kandungan terperinci 使用PHP要如何操作Redis?基本操作方法介绍. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Mod Redis cluster menyebarkan contoh Redis ke pelbagai pelayan melalui sharding, meningkatkan skalabilitas dan ketersediaan. Langkah -langkah pembinaan adalah seperti berikut: Buat contoh Redis ganjil dengan pelabuhan yang berbeza; Buat 3 contoh sentinel, memantau contoh redis dan failover; Konfigurasi fail konfigurasi sentinel, tambahkan pemantauan maklumat contoh dan tetapan failover; Konfigurasi fail konfigurasi contoh Redis, aktifkan mod kluster dan tentukan laluan fail maklumat kluster; Buat fail nodes.conf, yang mengandungi maklumat setiap contoh Redis; Mulakan kluster, laksanakan perintah Buat untuk membuat kluster dan tentukan bilangan replika; Log masuk ke kluster untuk melaksanakan perintah maklumat kluster untuk mengesahkan status kluster; buat

Masa depan PHP akan dicapai dengan menyesuaikan diri dengan trend teknologi baru dan memperkenalkan ciri -ciri inovatif: 1) menyesuaikan diri dengan pengkomputeran awan, kontena dan seni bina microservice, menyokong Docker dan Kubernetes; 2) memperkenalkan pengkompil JIT dan jenis penghitungan untuk meningkatkan prestasi dan kecekapan pemprosesan data; 3) Berterusan mengoptimumkan prestasi dan mempromosikan amalan terbaik.

Cara Mengosongkan Data Redis: Gunakan perintah Flushall untuk membersihkan semua nilai utama. Gunakan perintah flushdb untuk membersihkan nilai utama pangkalan data yang dipilih sekarang. Gunakan Pilih untuk menukar pangkalan data, dan kemudian gunakan FlushDB untuk membersihkan pelbagai pangkalan data. Gunakan perintah DEL untuk memadam kunci tertentu. Gunakan alat REDIS-CLI untuk membersihkan data.

PHP dan Python masing -masing mempunyai kelebihan mereka sendiri, dan memilih mengikut keperluan projek. 1.PHP sesuai untuk pembangunan web, terutamanya untuk pembangunan pesat dan penyelenggaraan laman web. 2. Python sesuai untuk sains data, pembelajaran mesin dan kecerdasan buatan, dengan sintaks ringkas dan sesuai untuk pemula.

PHP dan Python masing -masing mempunyai kelebihan sendiri, dan pilihannya harus berdasarkan keperluan projek. 1.Php sesuai untuk pembangunan web, dengan sintaks mudah dan kecekapan pelaksanaan yang tinggi. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan yang kaya.

PHP tetap penting dalam pembangunan web moden, terutamanya dalam pengurusan kandungan dan platform e-dagang. 1) PHP mempunyai ekosistem yang kaya dan sokongan rangka kerja yang kuat, seperti Laravel dan Symfony. 2) Pengoptimuman prestasi boleh dicapai melalui OPCACHE dan NGINX. 3) Php8.0 memperkenalkan pengkompil JIT untuk meningkatkan prestasi. 4) Aplikasi awan asli dikerahkan melalui Docker dan Kubernet untuk meningkatkan fleksibiliti dan skalabiliti.

Untuk membaca giliran dari Redis, anda perlu mendapatkan nama giliran, membaca unsur -unsur menggunakan arahan LPOP, dan memproses barisan kosong. Langkah-langkah khusus adalah seperti berikut: Dapatkan nama giliran: Namakannya dengan awalan "giliran:" seperti "giliran: my-queue". Gunakan arahan LPOP: Keluarkan elemen dari kepala barisan dan kembalikan nilainya, seperti LPOP Queue: My-Queue. Memproses Baris kosong: Jika barisan kosong, LPOP mengembalikan nihil, dan anda boleh menyemak sama ada barisan wujud sebelum membaca elemen.

Sebab mengapa PHP adalah timbunan teknologi pilihan untuk banyak laman web termasuk kemudahan penggunaannya, sokongan komuniti yang kuat, dan penggunaan yang meluas. 1) Mudah dipelajari dan digunakan, sesuai untuk pemula. 2) Mempunyai komuniti pemaju yang besar dan sumber yang kaya. 3) Digunakan secara meluas dalam platform WordPress, Drupal dan lain -lain. 4) Mengintegrasikan dengan ketat dengan pelayan web untuk memudahkan penggunaan pembangunan.
