黑马苍穹外卖4 店铺营业状态设置+Redis基础

2024-06-20 15:36

本文主要是介绍黑马苍穹外卖4 店铺营业状态设置+Redis基础,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

店铺营业状态设置

在这里插入图片描述
Redis MySQL Java并发 JavaMVC 计算机网络 操作系统 算法,后端面试主要是这些,外加项目

Redis

数据库,基于内存存储的key-value结构。
mysql是磁盘存储,通过二维表存储。
在这里插入图片描述
在文件夹目录打开cmd
服务端:
开启

redis-server.exe redis.windows.conf

客户端:
普通启动连接

redis-cli.exe

显示的指定服务端和端口号

redis-cli.exe -h localhost -p 6379

默认客户端不需要密码就能连接上。
修改配置文件
redis.windows.conf 里 指定密码为123456
requirepass 123456

不需要用户名,客户端链接需要添加上密码

redis-cli.exe -h localhost -p 6379 -a 123456

常用数据类型

value的数据类型,key是字符串
在这里插入图片描述
在这里插入图片描述
常用命令:
1.字符串
在这里插入图片描述
不区分大小写

在图形化界面里按左边栏上的>_
set 
setex 

2.哈希
在这里插入图片描述

hset
hget
hdel 
hkeys
kvals

3.列表操作
在这里插入图片描述

lpush mylist a b c//从左侧插入即从头
lrange mylist 0 -1 //从头到尾
rpop mylist //删最后一个
llen mylist

4.集合操作
在这里插入图片描述

>sadd set1 a b c d//表内顺序和插入顺序无关
4
>smembers set1
>scard set1
4
>sadd set2 a b x y
>sinter set1 set2
b
a
>sunion set1 set3
c
a
b
x
y

5.有序集合操作
在这里插入图片描述
会按照分数排序

>zrange zset1 0 -1
a
b
c
>zrange zset1 0 -1 withscores
a
10
b
10.1
c
11.1
>zincrby zset1 5.0 a//给a的值+5.0

6.通用命令
在这里插入图片描述

>type mylist
list
>type set1
set
>del name set1 zset1
3
>

Redis 的Java 客户端

在这里插入图片描述
用java操作
。。。
(1)操作字符串类型数据

    @Autowiredprivate RedisTemplate redisTemplate;@Testpublic void test01(){redisTemplate.opsForValue().set("name","小明"); // 设置k vString city = (String) redisTemplate.opsForValue().get("name"); // 拿到key为name的值System.out.println(city);redisTemplate.opsForValue().set("code","1234",3, TimeUnit.MINUTES); // 设置过期时间为三分钟redisTemplate.opsForValue().setIfAbsent("lock","1"); // 设置lock为k的唯一值redisTemplate.opsForValue().setIfAbsent("lock","2");}
小明

(2)操作哈希类型数据

    @Testpublic void test02(){//hset hget hdel hkeys hvalsHashOperations hashOperations = redisTemplate.opsForHash();hashOperations.put("100","name","tom"); // 设置k为100,哈希k为name v为100hashOperations.put("100","age","20");String name = (String) hashOperations.get("100", "name"); // 获取k为100,hashk为name的vSystem.out.println(name);Set keys = hashOperations.keys("100"); // 获取k为100的集合kSystem.out.println(keys);List values = hashOperations.values("100"); // 获取k为100的集合vSystem.out.println(values);hashOperations.delete("100","age"); // 删除age字段}
tom
[name,age]
[tom,20]

(3)操作列表类型数据

    @Testpublic void test03(){//lpush lrange rpop llenListOperations listOperations = redisTemplate.opsForList();listOperations.leftPushAll("mylist","a","b","c"); // 往k为mylist插入a,b,clistOperations.leftPush("mylist","d"); // 插入dList mylist = listOperations.range("mylist", 0, -1);System.out.println(mylist); // 输出listOperations.rightPop("mylist"); // 删除Long size = listOperations.size("mylist");System.out.println(size);System.out.println(listOperations.range("mylist", 0, -1));}
[d,c,b,a]
3
[d,c,b]

(4)操作集合类型数据

    @Testpublic void test4(){//sadd smembers scard sinter sunion sremSetOperations setOperations = redisTemplate.opsForSet();setOperations.add("set1","a","b","c","d"); // 往set1 插入abcdsetOperations.add("set2","a","b","x","y"); // 往set2 插入abxySet members = setOperations.members("set1");System.out.println(members); // 输出Long size = setOperations.size("set1");System.out.println(size); // 输出Set intersect = setOperations.intersect("set1", "set2"); // 他们的交集System.out.println(intersect);Set union = setOperations.union("set1", "set2");// 他们的并集System.out.println(union);setOperations.remove("set1","a","b"); // 在set1里面删除ab}
[a,b,c,d]
4
[a,b]
[a,b,c,d,x,y]

(5)操作有序集合类型数据

    /*** 操作有序集合类型的数据*/@Testpublic void test05(){//zadd zrange zincrby zremZSetOperations zSetOperations = redisTemplate.opsForZSet();zSetOperations.add("zset1","a",10); // 设置k为zset1v为a,分数为10zSetOperations.add("zset1","b",12); //同理zSetOperations.add("zset1","c",9); // 同理Set zset1 = zSetOperations.range("zset1", 0, -1);System.out.println(zset1); // 输出zSetOperations.incrementScore("zset1","c",10); // 为k为zset1v为c的加10分zSetOperations.remove("zset1","a","b"); // 删除ab}
[c,a,b]

(6)通用命令操作

    @Testpublic void test06(){//keys exists type delSet keys = redisTemplate.keys("*"); // 查找所有符合给定模式( pattern)的 key System.out.println(keys);Boolean name = redisTemplate.hasKey("name");Boolean set1 = redisTemplate.hasKey("set1");for (Object key : keys) {DataType type = redisTemplate.type(key); // 查找他们的类型是什么System.out.println(type.name());}redisTemplate.delete("mylist"); // 删除mylist}
[set2,zset1,set1]
SET
ZSET
SET

总结:
Spring Data Redis中提供了一个高度封装的类:RedisTemplate,对相关api进行了归类封装,将同一类型操作封装为operation接口,具体分类如下:

ValueOperations:string数据操作
SetOperations:set类型数据操作
ZSetOperations:zset类型数据操作
HashOperations:hash类型的数据操作
ListOperations:list类型的数据操作

回归正题:店铺营业状态设置

在这里插入图片描述
用户端与管理端一样只是路径变为/user/shop/status

admin.ShopController.java

@RestController("adminShopController")//为了区分他俩
@RequestMapping("/admin/shop")
@Slf4j
@Api(tags = "店铺相关接口")
public class ShopController {public static final String KEY="SHOP_STATUS";@Autowiredprivate RedisTemplate redisTemplate;//注入redis对象@PutMapping("/{status}")@ApiOperation("设置店铺运营状态")public Result setStatus(@PathVariable Integer status){redisTemplate.opsForValue().set("SHOP_STATUS",status);//保存状态值return Result.success();}@GetMapping("/status")@ApiOperation("显示店铺运营状态")public Result<Integer> getStatus(){Integer status = (Integer) redisTemplate.opsForValue().get(KEY);log.info("获取到店铺的营业状态为:{}",status == 1 ? "营业中":"打烊中");return Result.success();}}

为了避免两个Bean都叫shopController的冲突,所以用@RestController(“UserShopController”)//为了区分他俩
user.ShopController.java

@RestController("UserShopController")//为了区分他俩
@RequestMapping("/user/shop")
@Api(tags = "店铺相关接口")
@Slf4j
public class ShopController {public static final String KEY = "SHOP_STATUS";@Autowiredprivate RedisTemplate redisTemplate;@GetMapping("/status")@ApiOperation("显示店铺运营状态")public Result<Integer> getStatus() {log.info("店铺查询状态");return Result.success((Integer) redisTemplate.opsForValue().get(KEY));}}

另外:为了将接口文档的用户和admin的接口区分开
修改配置类,分别扫描两个包,分组展示,形成两份接口文档

@Beanpublic Docket docketOne() {ApiInfo apiInfo = new ApiInfoBuilder().title("苍穹外卖项目接口文档").version("2.0").description("苍穹外卖项目接口文档").build();Docket docket = new Docket(DocumentationType.SWAGGER_2).groupName("管理端接口")//分组.apiInfo(apiInfo).select().apis(RequestHandlerSelectors.basePackage("com.sky.controller.admin")).paths(PathSelectors.any()).build();return docket;}@Beanpublic Docket docketTwo() {ApiInfo apiInfo = new ApiInfoBuilder().title("苍穹外卖项目接口文档").version("2.0").description("苍穹外卖项目接口文档").build();Docket docket = new Docket(DocumentationType.SWAGGER_2).groupName("用户端接口")//分组.apiInfo(apiInfo).select().apis(RequestHandlerSelectors.basePackage("com.sky.controller.user")).paths(PathSelectors.any()).build();return docket;}

这篇关于黑马苍穹外卖4 店铺营业状态设置+Redis基础的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1078536

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

状态dp总结

zoj 3631  N 个数中选若干数和(只能选一次)<=M 的最大值 const int Max_N = 38 ;int a[1<<16] , b[1<<16] , x[Max_N] , e[Max_N] ;void GetNum(int g[] , int n , int s[] , int &m){ int i , j , t ;m = 0 ;for(i = 0 ;

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

hdu3006状态dp

给你n个集合。集合中均为数字且数字的范围在[1,m]内。m<=14。现在问用这些集合能组成多少个集合自己本身也算。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.Inp

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |