PHP で Redis データベースを操作する一般的な方法 (概要)
Redis は、ANSI C 言語で書かれたオープンソースのログタイプの Key-Value データベースで、ネットワークをサポートし、メモリベースで永続化でき、複数の言語で API を提供します。
Redis でサポートされるデータ型は、Stirng(string)
、List(list
)
、Hash(dictionary)## です。 #,
Set(set),
Sorted Set(順序セット);
1. redis をインストールします
git ダウンロード アドレスhttps://github.com/MSOpenTech/redis/releases
2. redis のテスト
Windows を実行し (ショートカット キー: Windows キー R キー)、[cmd] コマンドを入力して DOC オペレーティング システム ウィンドウに入ります。# redis インストール ディレクトリを入力し、コマンドを使用します。
2.1 redis デーモンを起動します (redis インストール ディレクトリに入力します)
redis-server.exe redis-windows-conf
2.2 redis クライアントを入力します ( redis インストール ディレクトリを入力します)
redis-cli.exe
3. php
ダウンロード アドレス
の Redis 拡張機能をインストールします。 https: //pecl.php.net/package/redisphpinfo() 情報に基づいて適切な Redis 拡張圧縮パッケージを選択します
4. Redis 拡張パッケージの 2 つのファイル php_redis.dll と php_redis.pdb は、ext フォルダー
5 に配置されます。php.ini ファイルを変更します
extension=php_redis.dll
##phpinfo() 情報を表示し、redis
#7 を検索します。 php 接続を実行し、redis データベースをテストします (redis サービスを有効にすることを忘れないでください)New test.php<?php
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
$redis->set('name','klc');
echo $redis->get('name');
?>
データ型の操作
Strng (文字列):<?php // 设置一个字符串的值 $redis->set('cat', 111); //获取一个字符串的值 echo $redis->get('cat'); // 111 // 重复set $redis->set('cat', 222); echo $redis->get('cat'); // 222
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 )
ハッシュ(辞書):
<?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 )
セット(セット):
<?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 )
<?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 )
ソートセット (順序セット):
<?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 )
関連する php の知識については、こちらをご覧ください。 phpチュートリアル!
以上がPHP で Redis データベースを操作する一般的な方法 (概要)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHPの将来は、新しいテクノロジーの傾向に適応し、革新的な機能を導入することで達成されます。1)クラウドコンピューティング、コンテナ化、マイクロサービスアーキテクチャに適応し、DockerとKubernetesをサポートします。 2)パフォーマンスとデータ処理の効率を改善するために、JITコンパイラと列挙タイプを導入します。 3)パフォーマンスを継続的に最適化し、ベストプラクティスを促進します。

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

Redisクラスターモードは、シャードを介してRedisインスタンスを複数のサーバーに展開し、スケーラビリティと可用性を向上させます。構造の手順は次のとおりです。異なるポートで奇妙なRedisインスタンスを作成します。 3つのセンチネルインスタンスを作成し、Redisインスタンスを監視し、フェールオーバーを監視します。 Sentinel構成ファイルを構成し、Redisインスタンス情報とフェールオーバー設定の監視を追加します。 Redisインスタンス構成ファイルを構成し、クラスターモードを有効にし、クラスター情報ファイルパスを指定します。各Redisインスタンスの情報を含むnodes.confファイルを作成します。クラスターを起動し、CREATEコマンドを実行してクラスターを作成し、レプリカの数を指定します。クラスターにログインしてクラスター情報コマンドを実行して、クラスターステータスを確認します。作る

PHPは死にかけていませんが、常に適応して進化しています。 1)PHPは、1994年以来、新しいテクノロジーの傾向に適応するために複数のバージョンの反復を受けています。 2)現在、電子商取引、コンテンツ管理システム、その他の分野で広く使用されています。 3)PHP8は、パフォーマンスと近代化を改善するために、JITコンパイラおよびその他の機能を導入します。 4)Opcacheを使用してPSR-12標準に従って、パフォーマンスとコードの品質を最適化します。

Redis指令を使用するには、次の手順が必要です。Redisクライアントを開きます。コマンド(動詞キー値)を入力します。必要なパラメーターを提供します(指示ごとに異なります)。 Enterを押してコマンドを実行します。 Redisは、操作の結果を示す応答を返します(通常はOKまたは-ERR)。

Redisサーバーを起動する手順には、以下が含まれます。オペレーティングシステムに従ってRedisをインストールします。 Redis-Server(Linux/Macos)またはRedis-Server.exe(Windows)を介してRedisサービスを開始します。 Redis-Cli ping(Linux/macos)またはRedis-Cli.exePing(Windows)コマンドを使用して、サービスステータスを確認します。 Redis-Cli、Python、node.jsなどのRedisクライアントを使用して、サーバーにアクセスします。

Redisを使用して操作をロックするには、setnxコマンドを介してロックを取得し、有効期限を設定するために有効期限コマンドを使用する必要があります。特定の手順は次のとおりです。(1)SETNXコマンドを使用して、キー価値ペアを設定しようとします。 (2)expireコマンドを使用して、ロックの有効期限を設定します。 (3)Delコマンドを使用して、ロックが不要になったときにロックを削除します。

Redisデータをクリアする方法:Flushallコマンドを使用して、すべての重要な値をクリアします。 FlushDBコマンドを使用して、現在選択されているデータベースのキー値をクリアします。 [選択]を使用してデータベースを切り替え、FlushDBを使用して複数のデータベースをクリアします。 DELコマンドを使用して、特定のキーを削除します。 Redis-CLIツールを使用してデータをクリアします。
