一.redis.php
<?php //实例化 $redis = new Redis(); //连接服务器 $redis->connect("localhost"); //授权 $redis->auth("lamplijie"); //相关操作 $redis->set("name","lampbrother"); $data = $redis->key("*"); var_dump($data);
页面显示结果:
array(1) { [0]=> string(4) "name" }
二.简单回顾redis的四种数据类型
a.string:最简单的数据类型
set user:001:name lijie set user:001:age 20
b.hash:可以当做表,hash table,比string速度快
hset user:001 name lamp age 20 hset user:001 sex nan hset user:002 name lijie age 20 hgetall user:001
c.list:栈、队列
d.set:并集、交集、差集
e.zset:set升级版,多了一个顺序
三.小型的用户管理系统(用户的增删改查、分页、登陆退出、加关注)
redis.php
<?php //实例化 $redis = new Redis(); //连接服务器 $redis->connect("localhost"); //授权 $redis->auth("lamplijie");
add.php
<form action="reg.php" method="post"> 用户名:<input type="text" name="username"/><br/> 密码:<input type="password" name="password"/><br/> 年龄:<input type="text" name="age"/><br/> <input type="submit" value="注册"/> <input type="reset" value="重新填写"/> </form>
reg.php
<?php require("redis.php"); $username = $_POST['username']; $password = md5($_POST['password']); $age = $_POST['age']; echo $uid = $redis->incr("userid"); $redis->hmset("user:".$uid,array("uid"=>$uid,"username"=>$username,"password"=>$password,"age"=>$age)); $redis->rpush("uid",$uid); $redis->set("username:".$username,$uid); header("location:list.php");list.php
<a href="add.php">注册</a> <?php require("redis.php"); if(!empty($_COOKIE['auth'])){ $id = $redis->get("auth:".$COOKIE['auth']); $name = $redis->hget("user:".$id,"username"); ?> 欢迎您,<?php echo $name?>,<a href="logout.php">退出</a> <?php }else{ ?> <a href="login.php">登陆</a> <?php } //用户总数 $count = $redis->lsize("uid"); //页大小 $page_size = 3; //当前页码 $page_num = (!empty($_GET['page']))?$_GET['page']:1; //页总数 $page_count = ceil($count/$page_size); $ids = $redis->lrange("uid",($page_num-1)*$page_size,(($page_num-1)*$page_size+$page_size-1)); //var_dump($ids); /* for($i=1;$i<=($redis->get("userid"));$i++) { $data[] = $redis->hgetall("user:".$i); }*/ foreach($ids as $v){ $data[] = $redis->hgetall("user:".$v); } //var_dump($data); //$data = array_filter($data); ?> <table border="1"> <tr> <th>uid</th> <th>username</th> <th>age</th> <th>操作</th> </tr> <?php foreach($data as $v){?> <tr> <td><?php echo $v['uid']?></td> <td><?php echo $v['username']?></td> <td><?php echo $v['age']?></td> <td> <a href="del.php?id=<?php echo $v['uid']?>">删除</a> <a href="mod.php?id=<?php echo $v['uid']?>">编辑</a> <?php if(!empty($_COOKIE['auth']) && $id!=$v['uid']){?> <a href="addfans.php?id=<?php echo $v['uid']?>&uid=<?php echo $id?>">加关注</a> <?php } ?> </td> </tr> <?php}?> <tr> <td colspan="4"> <a href="?page=<?php echo(($page_num-1)<=1)?1:($page_num-1) ?>">上一页</a> <a href="?page=<?php echo(($page_num+1)>=$page_count)?$page_count:($page_num+1) ?>">下一页</a> <a href="?page=1">首页</a> <a href="?page=<?php echo $page_count ?>">尾页</a> 当前<?php echo $page_num ?>页 总共<?php echo $page_count ?>页 总共<?php echo $count ?>个用户 </td> </tr> </table> <table border=1> <caption>我关注了谁</caption> <?php $data = $redis->smembers("user:".$id.":following");?> foreach($data as $v) { $row = $redis->hgetall("user:".$v); <tr> <td><?php echo $row['uid']?></td> <td><?php echo $row['username']?></td> <td><?php echo $row['age']?></td> </tr> <?php } ?> </table> <table border=1> <caption>我的粉丝</caption> <?php $data = $redis->smembers("user:".$id.":followers"); foreach($data as $v) { $row = $redis->hgetall("user:".$v); ?> <tr> <td><?php echo $row['uid']?></td> <td><?php echo $row['username']?></td> <td><?php echo $row['age']?></td> </tr> <?php } ?> </table>
del.php
<?php require("redis.php"); $uid = $_GET['id']; $redis->del("user:".$uid); $redis->lrem("uid",$uid); header("localhost:list.php");mod.php
<?php require("redis.php"); $uid = $_GET['id']; $data = $redis->hgetall("user:".$uid); ?> <form action="doedit.php" method="post"> <input type="hidden" value="<?php echo $data['uid']?>" name="uid"/> 用户名:<input type="text" name="username" value="<?php echo $data['username']?>"/><br/> 年龄:<input type="text" name="age" value="?php echo $[data['age']?>"/><br/> <input type="submit" value="修改"/> <input type="reset" value="重新填写"/> </form>
doedit.php
<?php $uid = $_POST['uid']; $username = $_POST['username']; $age = $_POST['age']; $a = $redis->hmset("user:".$uid,array("username"=>$username,"age"=>$age)); if($a) { header("location:list.php"); }else { header(location:mod.php?id=".$uid); }
login.php
<?php require("redis.php"); $username = $_POST['username']; $pass = $_POST['password']; $id = $redis->get("username:".$username); if(!empty($id)) { $password = $redis->hget("user:".$id,"password"); if(md5($pass) == $password) { $auth = md5(time().$username.rand()); $redis->set("auth:".$auth,$id); setcookie("auth", $auth, time() + 86400); header("location:list.php"); } } ?> <form action="" method="post"> 用户名:<input type="text" name="username"/><br/> 密码:<input type="password" name="password"/><br/> <input type="submit" value="登陆"/> </form>
logout.php
<?php setcookie("auth","",time()-1); header("location:list.php");
addfans.php
<?php $id = $_GET['id']; $uid = $_GET['uid']; require("redis.php"); $redis->sadd("user:".$uid.":following",$id); $redis->sadd("user:".$id.":followers",$uid); header("location:list.php");当然,采用sdiff user:1:following user:2:following语句,用户1可以向用户2推荐关注(即用户1的关注与用户2的关注的差集)。
相关推荐
- **Redis实例分析**:介绍如何利用Redis实现缓存、消息队列等功能。 #### 十二、API总结 - **MongoDB常用API总结**:提供了一系列API,包括插入、查询、更新和删除等操作。 - **Redis命令总结**:覆盖了连接操作...
1. redis-server.exe:这是Redis服务器的可执行文件,用于启动和管理Redis实例。 2. redis-cli.exe:Redis命令行客户端,可以用来与Redis服务器进行交互,如执行命令、查看数据等。 3. redis.conf:默认配置文件,...
PA195 NoSQL数据库-Redis运行一个实例# Create a network for a Redisdocker network create redisnet# Run a single instance that is automatically removed after being killeddocker run --rm --...
- 连接到本地或远程的Redis实例 - 实时查看键值对 - 新增、修改、删除键值 - 执行Redis命令 - 数据导入与导出 - 监控服务器状态和性能指标 2. **Redis-x64-3.0.504.zip**: 这个文件是Redis服务器的一个64位...
Redis 是一个广受欢迎的开源(BSD 许可)NoSQL 数据库系统,专注于提供高性能的键值存储服务。它的全称是 Remote Dictionary Server,最初由 Salvatore Sanfilippo 创建,现在已经成为许多应用程序后端数据存储的...
Redis 是一种流行的 NoSQL 数据库,可以用于缓存、消息队列、计数器等场景。使用 Docker 容器可以方便地部署和管理 Redis 集群。 Docker 容器的概念 在开始配置 Redis 集群之前,需要了解 Docker 容器的基本概念。...
Redis-server.exe是Redis服务器的执行程序,用于启动和管理Redis实例。在启动时,可以通过配置文件(默认为redis.conf)来设置各种参数,例如端口号、数据库数量、内存限制、持久化策略等。一旦启动,Redis服务器将...
Redis Desktop Manager是一款强大的图形化界面工具,用于管理和操作Redis数据库。...通过这个桌面应用,用户可以更轻松地管理和维护他们的Redis实例,无论是进行开发测试还是生产环境的监控与维护。
NoSQL(Not Only SQL)数据库应运而生,作为一种非关系型数据库管理系统,它提供了不同于传统SQL数据库的新方法来存储和查询数据。 **NoSQL数据库的特点:** 1. **可扩展性**:NoSQL数据库通常具有良好的水平扩展...
本篇将详细介绍NoSQL 数据库中的两个代表——Redis 和 MongoDB,并重点阐述它们在高级接口、数据处理、数据存储以及资源管理等方面的特点。 #### NoSQL 数据库概述 NoSQL 数据库的主要特点包括: - **灵活的模式...
- **并发访问限制:** 单一数据库实例难以支撑大规模并发读写请求。 #### 二、缓解瓶颈的方法 为了应对上述挑战,开发者们提出了多种策略: **1. Memcached + MySQL + 垂直拆分** - **Memcached作为缓存层:** ...
- 使用第三方工具,如RedisInsight、Redis Commander或自定义监控脚本,可以帮助可视化和监控Redis实例的性能指标。 7. **备份与恢复**: - Redis支持RDB(定期快照)和AOF(Append Only File)两种持久化方式,...
NoSQL数据库,全称为"Not Only SQL",是一种非关系型的数据库系统,旨在应对现代互联网应用中的大规模数据处理和高性能需求。随着Web2.0时代的到来,传统的基于关系型数据库的架构开始面临挑战,尤其是在处理高并发...
一个Redis实例可以作为主节点,多个其他实例作为从节点,从节点会实时同步主节点的数据。 3.持久化:Redis提供两种持久化机制,RDB(Redis Database Backup)和AOF(Append Only File)。RDB定期保存整个数据库的...
NoSQL数据库的出现,是对传统关系型数据库的一种补充,它主要通过去除了关系模型,为特定场景下的数据管理提供了更加灵活、高性能的解决方案。 NoSQL数据库的分类方式多样,但根据其存储原理,主要可以分为以下几种...
2019.0.0版本是该软件的一个特定发行版,提供了直观的用户界面,使得数据的存储、查看、编辑以及管理Redis实例变得更加简单。这个压缩包“redis-desktop-manager-2019.0.0安装包.7z”包含了用于在计算机上安装RDM的...
6. **多服务器管理**:同时连接和管理多个Redis实例,这对于拥有分布式环境或多个开发/测试/生产环境的团队来说非常实用。 7. **安全与权限**:理解Redis的访问控制和权限设置,确保数据的安全性。 8. **事务与...
- 多会话管理:支持多个Redis实例的连接,方便进行多数据库管理。 - 模型视图:通过树形结构展示数据库结构,清晰地呈现键的层级关系。 - 操作日志:记录所有对Redis服务器的读写操作,便于追踪和回溯。 3. **...
这款软件允许用户通过直观的界面来执行常见的Redis命令,查看、编辑、添加和删除数据,以及管理多个Redis实例。在"redis-desktop-manager-0.8.3.3850.zip"这个压缩包中,包含的是Redis Desktop Manager的0.8.3.3850...
Redis Desktop Manager 2020 是一款针对Windows 10操作系统设计的可视化Redis管理工具,专为提升数据库管理和操作的便捷性而打造。这款新版本的发布,为开发者和DBA们提供了更为直观和高效的界面,以处理和管理NoSQL...