Redis简单使用

Redis五种数据类型

Redis中所有的数据都是字符串。命令不区分大小写,key是区分大小写的。Redis是单线程的。Redis中不适合保存内容大的数据。

1.String:key-value
set key value
get key
getset key value
del key
incr:加一(生成id)
Decr:减一

2.Hash:key-fields-values(做缓存)
相当于一个key对于一个map,map中还有key-value
使用hash对key进行归类。
Hset:向hash中添加内容
Hget:从hash中取内容
hset key field value
key下面对应map的key和value分别是field和value
hmset key field value[field2 value2]
同时将多个field-value(域-值)对设置到哈希表key中。
hget key field 取出key下对应的map中 key为field的值
hmget key fields 取出多个field对应的值
hgetall key
hdel key field [field…]
del key

3.List:有顺序可重复
192.168.25.153:6379> lpush list1 a b c d
192.168.25.153:6379> lrange list1 0 -1

  1. “d”
  2. “c”
  3. “b”
  4. “a”
    192.168.25.153:6379> rpush list1 1 2 3 4
    (integer) 8
    192.168.25.153:6379> lrange list1 0 -1
  5. “d”
  6. “c”
  7. “b”
  8. “a”
  9. “1”
  10. “2”
  11. “3”
  12. “4”
    192.168.25.153:6379>
    192.168.25.153:6379> lpop list1
    “d”
    192.168.25.153:6379> lrange list1 0 -1
  13. “c”
  14. “b”
  15. “a”
  16. “1”
  17. “2”
  18. “3”
  19. “4”
    192.168.25.153:6379> rpop list1
    “4”
    192.168.25.153:6379> lrange list1 0 -1
  20. “c”
  21. “b”
  22. “a”
  23. “1”
  24. “2”
  25. “3”
    192.168.25.153:6379>

4.Set:元素无顺序,不能重复
192.168.25.153:6379> sadd set1 a b c c c d
(integer) 4
192.168.25.153:6379> smembers set1

  1. “b”
  2. “c”
  3. “d”
  4. “a”
    192.168.25.153:6379> srem set1 a
    (integer) 1
    192.168.25.153:6379> smembers set1
  5. “b”
  6. “c”
  7. “d”

5.SortedSet(zset):有顺序,不能重复
192.168.25.153:6379> zadd zset1 2 a 5 b 1 c 6 d
(integer) 4
192.168.25.153:6379> zrange zset1 0 -1

  1. “c”
  2. “a”
  3. “b”
  4. “d”
    192.168.25.153:6379> zrem zset1 a
    (integer) 1
    192.168.25.153:6379> zrange zset1 0 -1
  5. “c”
  6. “b”
  7. “d”
    192.168.25.153:6379> zrevrange zset1 0 -1
  8. “d”
  9. “b”
  10. “c”
    192.168.25.153:6379> zrange zset1 0 -1 withscores
  11. “c”
  12. “1”
  13. “b”
  14. “5”
  15. “d”
  16. “6”
    192.168.25.153:6379> zrevrange zset1 0 -1 withscores
  17. “d”
  18. “6”
  19. “b”
  20. “5”
  21. “c”
  22. “1”
    sismenber key member 判断指定成员是否存在域该set中
    存在返回1 不存在返回0

Key命令

Expire key second:设置key的过期时间
Ttl key:查看key的有效期
Persist key:清除key的过期时间。Key持久化。

192.168.25.153:6379> expire Hello 100
(integer) 1
192.168.25.153:6379> ttl Hello
(integer) 77

Redis持久化方案

Rdb:快照形式,定期把内存中当前时刻的数据保存到磁盘。Redis默认支持的持久化方案。
aof形式:append only file。把所有对redis数据库操作的命令,增删改操作的命令。保存到文件中。数据库恢复时把所有的命令执行一遍即可。
在redis.conf配置文件中配置。
Rdb:
在这里插入图片描述
aof
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个用于创建独立的、基于Spring的应用程序的框架,而Redis是一个开源的内存数据存储系统。结合使用Spring Boot和Redis可以实现高效的数据缓存和持久化。 在Spring Boot中使用Redis,首先需要在项目的pom.xml文件中添加Redis的依赖。然后,在application.properties或application.yml文件中配置Redis的连接信息,包括主机名、端口号、密码等。 接下来,可以通过使用Spring Data Redis来简化对Redis的操作。Spring Data Redis提供了一系列的注解和模板类,可以方便地进行数据的读取、写入和删除等操作。 以下是一个简单的示例,演示了如何在Spring Boot中使用Redis: 1. 添加依赖: 在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 2. 配置Redis连接信息: 在application.properties或application.yml文件中添加以下配置: ```properties spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password= ``` 3. 创建Redis操作类: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; @Component public class RedisUtil { @Autowired private RedisTemplate<String, Object> redisTemplate; public void set(String key, Object value) { redisTemplate.opsForValue().set(key, value); } public Object get(String key) { return redisTemplate.opsForValue().get(key); } public void delete(String key) { redisTemplate.delete(key); } } ``` 4. 使用Redis操作类: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RestController; @RestController public class UserController { @Autowired private RedisUtil redisUtil; @GetMapping("/user/{id}") public User getUser(@PathVariable String id) { // 先从缓存中获取数据 User user = (User) redisUtil.get("user:" + id); if (user == null) { // 如果缓存中不存在,则从数据库中获取数据 user = userService.getUserById(id); // 将数据存入缓存 redisUtil.set("user:" + id, user); } return user; } } ``` 以上示例中,我们创建了一个RedisUtil类来封装对Redis的操作,然后在UserController中使用RedisUtil来实现对用户数据的缓存。当请求用户数据时,先从缓存中获取,如果缓存中不存在,则从数据库中获取,并将数据存入缓存。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值