Maison base de données Redis Quelles sont les méthodes d'utilisation de Redis dans Laravel ?

Quelles sont les méthodes d'utilisation de Redis dans Laravel ?

May 31, 2023 pm 01:43 PM
laravel redis

1. opération set/get

普通得set/get操作,set操作,如果键名存在,则会覆盖原有得值

    $redis = app("redis.connection");

    $redis->set('library' , 'phpredis');//存储key为library ,值phpredis得记录

    $redis->get("library");//获取key为library得记录值


set/get 多个key-value

    $mkv = array(

        "user:001"=>'First user',

        "user:002"=>"Second user",

        "user:003"=>"Third user"

    );

   $redis->mset($mkv); // 存储多个key对应的value

   $retval = $redis->mget( array_keys($mkv) );//获取多个key对应的value


setex 存放带存储时效的记录

    $redis->setex("library" , 10 , 'phpredis');  //存储key为library,值为phpredis的记录,有效时长为10秒


add操作,不会覆盖已有值

    $redis->setnx("foo" , 12); //返回true, 添加成功  存在不做任何操作  否则创建

    $redis->setnx('foo' , 34); //返回false ,添加失败,因为存在键名foo的记录


getset 是 set的变种,结果返回替换前的值

    $redis->getset('foo' , 56);//返回12;如果之前不存在记录,则返回null
Copier après la connexion

2. incrby/incr/decrby/decr incrément et décrémentation de valeur

$redis->incr('foo'); //返回57 ,递增 阶梯为1

    $redis->incrby('foo' , 2); //返回59 递增 阶梯为2
Copier après la connexion

3. L'existence renvoie 1, sinon renvoie 0

    $redis->exists("foo");
Copier après la connexion

4. , string Renvoie la chaîne, list renvoie la liste, set table renvoie set/zset, la table de hachage renvoie hash

    $redis->type('foo');
Copier après la connexion

5 l'ajout est connecté à l'opération de remplacement partiel string

    $redis->get('str');//返回test

    $redis->append('str' , "_123");
Copier après la connexion

6 existante et renvoie la longueur de la chaîne

    $redis->setrange('str' , 0 , 'abc'); //返回3,第2个参数为0等同于set操作

    $redis->setrange('str' , 2 , 'cd'); //返回4,表示从第2个字符后替换,这时‘str’ 为 ‘abcd’
Copier après la connexion

. 7. opération d'acquisition partielle substr

    $redis->substr('str' , 0 , 2);//返回abc 表示从第0个起,取到第2个字符串

    $redis->strlen('str'); // 返回4 此时‘str’ 为‘abcd’
Copier après la connexion

8, stockage de bits setbit

   $redis->setbit('library' , 31 ,1); // 表示在第31位存入1

getbit 位获取

    $redis->getbit('library' , 31); //返回1
Copier après la connexion

9, fonction de recherche floue des touches, prend en charge le signe * et ? (correspond à un caractère)

    $redis->set('foo1',123);

    $redis->set('foo2' , 456);

    $redis->keys('foo*'); //返回foo1和foo2的array

    $redis->keys('f?0?'); // 同上
Copier après la connexion

10. renvoie aléatoirement une méthode key

   $redis->randomkey(); //可能是返回‘foo1’ 或者是foo2 及其它任何已存在的key
Copier après la connexion

11 pour renommer la clé. La différence est que renamenx ne permet pas de passer à une clé existante

     $redis->rename('str','str2'); // 把原先命名为 str 的key改成了 str2
Copier après la connexion

12. -value timeliness

ttl  获取剩余有效期

    persist  重新设置为永久存储

    $redis->expire('foo' , 10);//设置有效期为10秒

    $redis->ttl('foo'); // 返回剩余有效期值10秒

    $redispersist("fool");//取消有效期,变为永久存储
Copier après la connexion

13. dbsize renvoie le nombre total d'enregistrements dans la base de données redis actuelle

  $redis->dbsize();
Copier après la connexion

14. Opération de file d'attente

rpush/rpushx有序列表操作,从队列后插入元素;

lpush/lpushx和rpush/rpushx的区别是插入到队列的头部,同上,‘x’含义是只对已存在的key进行操作

    $redis->rpush('foolist' , 'bar1'); //返回列表长度1

    $redis->rpush('foolist' , 'bar0'); // 返回列表长度2

    $redis->rpushx('foolist' , 'bar2'); // 返回3 , rpushx只对已存在的队列做添加,否则返回0

    $redis->llen('foolist'); //返回 3


lrange 返回队列中一个区间的元素

    $redis->lrange('foolist' , 0 , 1); //返回数组包含第0个至第1个,共2个元素

    $redis->lrange('foolist' , 0 , -1);//返回第0个至倒数第一个,相当于返回所有元素  


lindex 返回指定顺序位置的list元素


    $redis->lindex('foolist' , 1); //返回bar1


lset 修改队列中指定位置的value 

    $redis->lset('foolist' , 1 ,'123'); // 修改位置1的元素,返回true



lrem 删除队列中左起指定数量的字符

    $redis->lrem("foolist" , 1 , '_'); //删除队列中左起(右起使用-1)1个字符‘_’(若有)



lpop/rpop 类似栈结构地弹出(并删除)最左或最右的一个元素


    $redis->lpop('foolist');//左侧返回

    $redis->rpop('foolist'); // 右侧返回



ltrim 队列修改,保留左边起若干元素,其余删除

    $redis->ltrim('foolist' , 0 , 1);   //  保留左边起第0个至第1个元素


rpoplpush 从一个队列中pop元素并push到另一个队列

    $redis->rpush('list1' , 'ab0');

    $redis->rpush('list1','ab1');

    $redis->rpush('list2' , 'ab2');

    $redis->rpush('list2' , "ab3");

    $redis->rpoplpush('list1' , "list2"); 

    $redis->rpoplpush('list2' , 'list2'); 


linsert在队列的中间指定元素前或后插入元素


    $redis->linsert('list2' , 'before' , 'ab1' , '123');//表示在元素 ‘ab1’ 之前插入‘123’

    $redis->linser('list2' , 'after' , 'ab1' , "456");//表示在元素 ‘ab1’ 之后插入


blpop/brpop 阻塞并等待一个队列不为空时,在pop出最左或最右的一个元素(这个功能在php以外可以说非常好用)


    $redis->blpop('list3' , 10) ; //如果list3 为空则一直等待,知道不为空时将第一个元素弹出,10秒后超时
Copier après la connexion

15. Opération de table

sadd增加set集合元素,返回true,重复返回false

    $redis->sadd('set1' , 'ab');

    $redis->sadd('set1' , 'cd');

    $redis->sadd('set1' , 'ef');

    $redis->smembers("set1");  // 查看集合元素


srem 移除指定元素

    $redis->srem('set1' , 'cd');//删除‘cd’ 元素


spop弹出首元素

    $redis->spop("set1");//返回‘ab’


smove移动当前set集合的指定元素到另一个set集合

    $redis->sadd("set2",'123');

    $redis->smove('set1','set2','ab');//移动set1中的ab到set2 ,返回true or false;此时 set1 集合不存在 ab 这个值


scard 返回当前set表元素个数

    $redis->scard('set2');//返回2


sismember判断元素是否属于当前set集合

    $redis->sismember('set2','123'); //返回true or false


smembers返回当前set集合的所有元素

    $redis->smember('set2'); //返回array(123,ab)


sinter/sunion/sdiff 返回两个表中的交集/并集/补集

    $redis->sadd('set1' , 'ab');

    $redis->sinter('set2' , 'set1');//返回array('ab');

sinterstore/sunionstore/sdiffstore 将两个表交集/并集/补集元素copy到第三个表中

    $redis->set('foo' , 0);

    $redis->sinterstore('foo' , 'set1');//等同于将set1 的内容copy到foo中,并将foo转为set表

    $redis->sinterstore('foo' , array('set1' , 'set2'));//将set1和set2中相同的元素copy到foo表中,覆盖foo原有内容

srandmember 返回表中一个随即元素

    $redis->srandmember('set1');
Copier après la connexion

18, opération de tri

zadd增加元素,并设置序号,成功返回true,重复返回false

    $redis->zadd("zset1" , 1 , 'ab');

    $redis->zadd('zset1' , 2 , 'cd');

    $redis->zadd('zset1' , 3 , 'ef');

    zincrBy对指定元素索引值的增减,改变元素排序次序

    $redis->zincryBy('zset1' , 10 , 'ab');  //返回11


zrem 移除指定元素

    $redis->zrem('zset1' , 'ef');//返回true  or  false


zrange按位置次序返回表中指定区间的元素

    $redis->zrange("zset1" , 0 , 1);//返回位置0 和 1 之间(两个)的元素

    $redis->zrange('zset1' , 1 , -1);//返回位置0和倒数第一个元素之间的元素(相当于所有元素)


zrevrange同上,返回表中指定区间的元素,按次序倒排

    $redis->zrevrange('zset1' , 0 ,-1);//元素顺序和zrange相反


zrangeByscore/zrevrangeByscore 按顺序/降序返回表中指定索引区间的元素

    $redis->zadd('zset1' , 3 , 'ef');

    $redis->zadd('zset1' , 5 , 'gh');

    $redis->zrangeByscore('zset1' , 2, 9);//返回索引值2-9之间的元素array('ef' , 'gh');

    $redis->zrangeByscore('zset1' , 2 ,9 ,array('withscores'=>true , 'limit'=>array(1,2)));
    //返回索引值2-9之间的元素,withscores=>true表示包含索引值;limit=>array(1,2),表示偏移1,返回2条,结果为array(array('ef',3),array('gh',5))


zcount统计一个索引区间的元素个数

    $redis->zcount('zset1' , 3 , 5);//返回2

    $redis->zcount('zset1' , '(3' , 5 ) );//’(3‘ 表示索引的值在3-5之间但不含3,同理也可以使用’(5‘ 表示上限为5但不含5


zcard 统计元素个数

    $redis->zcard('zset1');//返回4


zremrangeByscore删除一个索引区间的元素

    $redis->zremrangeByscore('zset1' , 0 ,  2);//删除索引在0-2之间的元素(ab ,  cd),返回删除元素个数2


zrank/zrevrank返回元素所在表顺序/降序的位置(不是索引)

    $redis->zrank('zset1' , 'ef');//返回0,因为它是一个元素;zrevrank则返回1(最后一个)

zremrangeByrank删除表中指定位置区间的元素

    $redis->zremrangeByrank('zset1' , 0  ,  10);//删除位置为0-10的元素,返回删除的元素个数2
Copier après la connexion

19, opération de gestion Redis

    $redis->hset('hash1' , 'key1' , 'v1');//将key为key1,value为v1的元素存入hash1表

    $redis->hset("hash1" , 'key2' , 'v2');

    $redis->hget('hash1' , 'key1');//取出表hash1中的key   key  key1的值,返回v1


hexists返回hash表中的指定key是否存在

    $redis->hexists("hash1" , 'key1');//true 或 false


hdel 删除hash表中指定key的元素

    $redis->hdel('hash' , 'key2');//true  or  false


hlen 返回hash表元素个数

    $redis->hlen('hash1'); // 返回1


hsetnx增加一个元素,但不能重复

    $redis->hsetnx('hash1' , 'key1' , 'v2');

    $redis->hsetnx('hash1' , 'key2' , 'v2');


hmset/hmget存取多个元素到hash表

    $redis->hmset( 'hash1' , array('key3'=>'v3' , 'key4'=>'v4' ) );

    $redis->hmget( 'hash1' , array('key3' , 'key4') );//返回响应的值 array('v3' , 'v4');


hincryby 对指定key进行累加

    $redis->hincryBy('hash1' , 'key5' ,  3); //不存在,则存储并返回3 ;存在,即返回原有值 +3

    $redis->hincryBy("hash1" , 'key5' , 10);//返回13


hkeys返回hash表中的所有key

    $redis->hkeys('hash1'); // 返回array('key1' , 'key2' , 'key3' , 'key4' , 'key5');


hvals 返回hash表中的所有value

    $redis->hvals('hash1'); // 返回array('v1' , 'v2' , 'v3' , 'v4' , 13);


hgetall返回整个hash表元素

    $redis->hgetall('hash1');//返回hash1所有表元素
Copier après la connexion

opération redis

sort排序

    $redis->rpush('tab' , 3);

    $redis->rpush('tab' , 2);

    $redis->rpush('tab' , '17');

    $redis->sort('tab');//返回array(2,3,17);

    $redis->sort('tab' , array('sort'=>'desc'));//降序排序,返回array(17 , 3, 2)

    $redis->sort('tab' , array('limit'=>array(1,2)));//返回顺序位置中1的元素2个(这里的2是指个数,而不是位置),返回array(3,17)

    $redis->sort('tab' , array('limit'=>array('alpha'=>true)));//按首字符排序返回array(17 , 2 , 3 ),因为17的首字符是 1 所以排首位置

    $redis->sort('tab' , array('limit'=>array('store'=>'ordered')));//表示永久性排序,返回元素个数

    $redis->sort('tab' , array("limit"=>array('get'=>'pre_*')));//使用了通配符 * 过滤元素,表示只返回以pre开头的元素
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment construire le mode Cluster Redis Comment construire le mode Cluster Redis Apr 10, 2025 pm 10:15 PM

Le mode Redis Cluster déploie les instances Redis sur plusieurs serveurs grâce à la rupture, à l'amélioration de l'évolutivité et de la disponibilité. Les étapes de construction sont les suivantes: Créez des instances de redis étranges avec différents ports; Créer 3 instances Sentinel, Moniteur Redis Instances et basculement; Configurer les fichiers de configuration Sentinel, ajouter des informations d'instance Redis de surveillance et des paramètres de basculement; Configurer les fichiers de configuration d'instance Redis, activer le mode de cluster et spécifier le chemin du fichier d'informations de cluster; Créer un fichier nœuds.conf, contenant des informations de chaque instance redis; Démarrez le cluster, exécutez la commande CREATE pour créer un cluster et spécifiez le nombre de répliques; Connectez-vous au cluster pour exécuter la commande d'informations de cluster pour vérifier l'état du cluster; faire

Comment effacer les données redis Comment effacer les données redis Apr 10, 2025 pm 10:06 PM

Comment effacer les données Redis: utilisez la commande flushall pour effacer toutes les valeurs de clé. Utilisez la commande flushdb pour effacer la valeur clé de la base de données actuellement sélectionnée. Utilisez SELECT pour commuter les bases de données, puis utilisez FlushDB pour effacer plusieurs bases de données. Utilisez la commande del pour supprimer une clé spécifique. Utilisez l'outil Redis-CLI pour effacer les données.

Comment utiliser la commande redis Comment utiliser la commande redis Apr 10, 2025 pm 08:45 PM

L'utilisation de la directive Redis nécessite les étapes suivantes: Ouvrez le client Redis. Entrez la commande (Verbe Key Value). Fournit les paramètres requis (varie de l'instruction à l'instruction). Appuyez sur Entrée pour exécuter la commande. Redis renvoie une réponse indiquant le résultat de l'opération (généralement OK ou -err).

Comment lire le code source de Redis Comment lire le code source de Redis Apr 10, 2025 pm 08:27 PM

La meilleure façon de comprendre le code source redis est d'aller étape par étape: familiarisez-vous avec les bases de Redis. Sélectionnez un module ou une fonction spécifique comme point de départ. Commencez par le point d'entrée du module ou de la fonction et affichez le code ligne par ligne. Affichez le code via la chaîne d'appel de fonction. Familiez les structures de données sous-jacentes utilisées par Redis. Identifiez l'algorithme utilisé par Redis.

Comment implémenter le redis sous-jacent Comment implémenter le redis sous-jacent Apr 10, 2025 pm 07:21 PM

Redis utilise des tables de hachage pour stocker les données et prend en charge les structures de données telles que les chaînes, les listes, les tables de hachage, les collections et les collections ordonnées. Redis persiste les données via des instantanés (RDB) et ajoutez les mécanismes d'écriture uniquement (AOF). Redis utilise la réplication maître-esclave pour améliorer la disponibilité des données. Redis utilise une boucle d'événement unique pour gérer les connexions et les commandes pour assurer l'atomicité et la cohérence des données. Redis définit le temps d'expiration de la clé et utilise le mécanisme de suppression paresseux pour supprimer la clé d'expiration.

Comment lire la file d'attente redis Comment lire la file d'attente redis Apr 10, 2025 pm 10:12 PM

Pour lire une file d'attente à partir de Redis, vous devez obtenir le nom de la file d'attente, lire les éléments à l'aide de la commande LPOP et traiter la file d'attente vide. Les étapes spécifiques sont les suivantes: Obtenez le nom de la file d'attente: Nommez-le avec le préfixe de "Fitre:" tel que "Fitre: My-Quyue". Utilisez la commande LPOP: éjectez l'élément de la tête de la file d'attente et renvoyez sa valeur, telle que la file d'attente LPOP: My-Queue. Traitement des files d'attente vides: si la file d'attente est vide, LPOP renvoie NIL et vous pouvez vérifier si la file d'attente existe avant de lire l'élément.

Comment utiliser Redis Lock Comment utiliser Redis Lock Apr 10, 2025 pm 08:39 PM

L'utilisation des opérations Redis pour verrouiller nécessite l'obtention du verrouillage via la commande setnx, puis en utilisant la commande Expire pour définir le temps d'expiration. Les étapes spécifiques sont les suivantes: (1) Utilisez la commande setnx pour essayer de définir une paire de valeurs de clé; (2) Utilisez la commande Expire pour définir le temps d'expiration du verrou; (3) Utilisez la commande del pour supprimer le verrouillage lorsque le verrouillage n'est plus nécessaire.

Comment faire du message middleware pour redis Comment faire du message middleware pour redis Apr 10, 2025 pm 07:51 PM

Redis, en tant que Message Middleware, prend en charge les modèles de consommation de production, peut persister des messages et assurer une livraison fiable. L'utilisation de Redis comme Message Middleware permet une faible latence, une messagerie fiable et évolutive.

See all articles