redis总

redis汇总

1.简介

Redis 是完全开源免费的,遵守BSD协议,是一个高性能的 key-value 数据库。

Redis 与其他 key-value 缓存产品有以下三个特点:

  • Redis 支持数据的持久化,可以将内存汇总的数据保持在磁盘中,重启的时候可以再次加载进行使用。
  • Redis 不仅仅支持简单的 key-value 类型的数据,同时好提供 list ,set,zset,hash 等数据结构的存储
  • Redis 支持数据的备份,即 master-slave 模式的数据备份。

2.命令

2.1String

string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。

string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
注意: 一个键最大能存储512MB。
命令链接String命令

2.2List

Redis 列表是简单的字符串列表按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。
命令链接List命令

2.3Hash

Redis hash 是一个键值(key=>value)对集合。

Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象
实例中我们使用了 Redis HMSET, HGET 命令,HMSET 设置了两个 field=>value 对, HGET 获取对应 field 对应的 value

每个 hash 可以存储 232-1 键值对(40多亿)。
命令链接Hash命令

2.4Set

Redis的Set是string类型的无序集合

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

  • 添加一个string元素到,key对应的set集合中,成功返回1,
  • 如果元素以及在集合中返回0,
  • key对应的set不存在返回错误。
    注意: 数据 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。

集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
命令链接Set命令

2.5Zset

Redis zset 和 set 一样也是string类型元素的集合(有序集合),且不允许重复的成员

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复

向名称为key的zset中添加元素member,score用于排序,如果该元素存在,则更新其顺序
命令链接Zset命令

3.java中的正则表达式

参考1
参考2

public class PatternDemo {
    public static void main(String[] args) {

        String regex = "\\d+";
        String str = "a11a11";
        //匹配
        boolean matches = str.matches(regex);
        System.out.println(matches);
        //替换
        String str2 = str.replaceAll(regex, "p");
        System.out.println(str2);
        //分割
        String[] split = str.split(regex);
        for (String st:split){
            System.out.println(st);
        }
        //获取
        Pattern p = Pattern.compile(regex);
        Matcher m = p.matcher(str);
        while (m.find()){
            System.out.println(m.group());
        }
    }
}

结果:

false
apap
a
a
11
11

4.StringRedisTemplate

maven的依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

配置文件

#redis的ip地址  
spring.redis.hostName=127.0.0.1
#数据库,默认为0
spring.redis.database=0
#端口号  
spring.redis.port=6379
#如果有密码  
spring.redis.password=
#客户端超时时间单位是毫秒 默认是2000 
spring.redis.timeout=10000

StringRedisTemplate使用

stringRedisTemplate.opsForValue();//操作字符串
stringRedisTemplate.opsForHash();//操作hash
stringRedisTemplate.opsForList();//操作list
stringRedisTemplate.opsForSet();//操作set
stringRedisTemplate.opsForZSet();//操作有序set

示例

public class RedisService {
    @Autowired
    StringRedisTemplate stringRedisTemplate;

    /**
     * stringRedisTemplate基本操作
     */
    public void redis(){
        stringRedisTemplate.opsForValue().set("key", "value",60*5, TimeUnit.SECONDS);//向redis里存入数据和设置缓存时间(5分钟)
        stringRedisTemplate.boundValueOps("key").increment(-1);//val做-1操作
        stringRedisTemplate.opsForValue().get("key");//根据key获取缓存中的val
        stringRedisTemplate.boundValueOps("key").increment(1);//val +1
        stringRedisTemplate.getExpire("key");//根据key获取过期时间
        stringRedisTemplate.getExpire("key",TimeUnit.SECONDS);//根据key获取过期时间并换算成指定单位
        stringRedisTemplate.delete("key");//根据key删除缓存
        stringRedisTemplate.hasKey("key");//检查key是否存在,返回boolean值
        stringRedisTemplate.opsForSet().add("key", "1","2","3");//向指定key中存放set集合
        stringRedisTemplate.expire("key",1000 , TimeUnit.MILLISECONDS);//设置过期时间
        stringRedisTemplate.opsForSet().isMember("key", "1");//根据key查看集合中是否存在指定数据
        stringRedisTemplate.opsForSet().members("key");//根据key获取set集合

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值