本文最后更新于1 天前,其中的信息可能已经过时,如有错误请发送邮件到1169063119@qq.com
Redis简介
Redis是一个基于内存的key-value结构数据库。redis并不是用来取代MySQL的,而是对MySQL的补充。
特点:
- 基于内存存储,可读性能高
- 适合存储热点数据(咨询、新闻等一段时间的热度)
- 企业应用广泛
五种常用数据类型
redis存储的是key-value结构的数据,其中key是字符串类型,value有五种常用的数据类型
字符串string:普通字符串,redis中最简单的数据类型
哈希hash:也叫散列,类似于Java中的HashMap结构,哈希表中value部分是一个哈希表,在整个哈希表中键和值又是一个简单的字符串
列表list:按照插入顺序排序,可以有重复元素,类似于java中的LinkedList
集合set:无序集合,没有重复元素,类似于Java中的HashSet
有序集合sorted set/zset:集合中没个元素关联一个分数,根据分数升序排序,没有重复元素
Redis常用命令
字符串操作命令
set key vaue | 设置指定key的值 |
get key | 获取指定key的值 |
setex key seconds value | 设置指定key的值,并将key的过期时间设置为seconds秒 |
setnx key value | 只有在key不存在时设置key的值 |
public void testString(){
redisTemplate.opsForValue().set("city","北京");
String city = (String) redisTemplate.opsForValue().get("city");
System.out.println(city);
redisTemplate.opsForValue().set("code","1234",3, TimeUnit.MINUTES); // 设置过期时间3分钟
redisTemplate.opsForValue().setIfAbsent("lock","1");
redisTemplate.opsForValue().setIfAbsent("lock","2");
}
哈希操作命令
Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象,常用命令:
hset key field value | 将哈希表key中的字段field的值设为value |
hget key field | 获取存储在哈希表中指定字段的值 |
hdel key field | 删除存储在哈希表中的指定字段 |
hkeys key | 获取哈希表中所有字段 |
hvals key | 获取哈希表中所有值 |
public void testHash(){
HashOperations hashOperations = redisTemplate.opsForHash(); // 操作hash
//设置值
hashOperations.put("100","name","张三");
hashOperations.put("100","age",18);
//获取值
String name = (String) hashOperations.get( "100","name");
System.out.println(name);
Set keys = hashOperations.keys("100");
System.out.println(keys);
List values = hashOperations.values("100");
System.out.println(values);
hashOperations.delete("100","name");
}
列表操作命令
Redis列表是简单的字符串列表,按照插入顺序排序,常用命令:
lpush key value1 [value2] | 将一个或多个值插入到列表头部 |
lrange key start stop | 获取列表指定范围内的元素 |
rpop key | 移除并获取列表最后一个元素 |
llen key | 获取列表元素 |
public void testList(){
ListOperations listOperations = redisTemplate.opsForList();
listOperations.leftPushAll("mylist","1", "2","3");
listOperations.leftPush( "mylist","4");
List mylist = listOperations.range("mylist", 0, -1);
System.out.println(mylist);
listOperations.rightPop("mylist");
Long size = listOperations.size("mylist");
System.out.println(size);
}
集合操作命令
Redis set是string类型的无序集合。集合成员是唯一的,集合中不能出现重复的数据,常用命令:
sadd key member1 [member2] | 向集合添加一个或多个成员 |
smembers key | 返回集合中的所有成员 |
scard key | 获取集合的成员数 |
sinter key1 [key2] | 返回给定所有集合的交集 |
sunion key1 [key2] | 返回给定所有集合的并集 |
srem key member1 [member2] | 删除集合中一个或多个成员 |
public void testSet(){
SetOperations setOperations = redisTemplate.opsForSet();
setOperations.add("mySet1","1","2","3","4");
setOperations.add("mySet2","1", "b","c","d");
Set members = setOperations.members("mySet1");
System.out.println( members);
Long size = setOperations.size("mySet1");
System.out.println(size);
Set intersect = setOperations.intersect("mySet1", "mySet2");
System.out.println(intersect);
Set union = setOperations.union("mySet1", "mySet2");
System.out.println(union);
setOperations .remove("mySet1","1","2");
}
有序集合操作命令
Redis有序集合是string类型元素的集合,且不允许有重复成员。每一个元素都会关联一个double类型的分数。常用命令:
zadd key score1 member1 [score2 member2] | 向有序集合添加一个或多个成员 |
zrange key start stop [withscores] | 通过索引区间返回有序集合中指定区间内的成员 |
zincrby key increment member | 有序集合中对指定成员的分数加上增量increment |
zrem key member [member] | 移除有序集合中的一个或多个成员 |
public void testZset(){
ZSetOperations zSetOperations = redisTemplate.opsForZSet();
zSetOperations.add("myzset1", "a", 1);
zSetOperations.add("myzset1", "b", 2);
zSetOperations.add("myzset1","c",3);
Set myzset1 = zSetOperations.range("myzset1", 0, -1);
System.out.println(myzset1);
zSetOperations.incrementScore("myzset1", "a", 2) ; // a的分数加2
zSetOperations .remove("myzset1", "a", "b");
}
通用命令
Redis的通用命令是不分数据类型的,都可以使用的命令:
keys pattern | 检查所有符合给定模式的key |
exists key | 检查给定key是否存在 |
type key | 返回key所存储的值的类型 |
del key | 该命令用于在key存在时删除key |
public void testCommon(){
Set keys = redisTemplate.keys("*");
System.out.println(keys);
Boolean name = redisTemplate.hasKey("name");
Boolean myset1 = redisTemplate.hasKey("myset1");
for (Object key : keys){
DataType type = redisTemplate.type(key);
System.out.println(type.name());
}
redisTemplate.delete("mylist");
}
Redis的java客户端
Redis的java客户端很多,常用的几种:
- jedis
- lettuce
- spring data redis
spring data redis是spring的一部分,对redis底层开发包进行了高度封装。在spring项目中,可以使用spring data redis来简化操作。
Spring Data Redis使用方式
- 导入spring data redis的maven坐标
- 配置redis数据源
- 编写配置类,创建redistemplate对象
- 通过redistemplate对象操作redis