redis相关
Posted 贱贱的小帅哥
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis相关相关的知识,希望对你有一定的参考价值。
Redis 与其他 key - value 缓存产品有以下三个特点:
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
- Redis支持数据的备份,即master-slave模式的数据备份。
Redis 优势
- 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
- 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
- 原子 – Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。
- 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
---------------------------------------------------------
安装成功后:
-----------------------------------------------------------------------
Redis 数据类型
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
string (字符串):最大能存储 512MB
hash(哈希):是一个 string 类型的 field 和 value 的映射表
list(列表):Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
set(集合):Redis 的 Set 是 string 类型的无序集合。
zset(sorted set:有序集合):Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
------------------------------------
java操作redis
package dataMonitor.datawarehouse;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import redis.clients.jedis.Jedis;
public class RedisDemo {
static Jedis jedis = new Jedis("172.16.193.200", 6379);
public static void main(String[] args) {
System.out.println("连接成功------->" + jedis.ping());
//testString();
testMap();
}
public static void testString() {
// 添加数据
jedis.set("name", "danyu");
System.out.println(jedis.get("name"));
// 拼接字符串
jedis.append("name", "wang");
System.out.println(jedis.get("name"));
// 删除数据
jedis.del("name");
System.out.println(jedis.get("name"));
// 设置多个键值对
jedis.mset("name", "yc", "age", "22", "qq", "1933108196");
jedis.incr("age");// 加1操作
System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));
}
public static void testMap() {
// 添加数据
Map<String, String> map = new HashMap<String, String>();
map.put("name", "yc");
map.put("age", "22");
map.put("qq", "1933108196");
jedis.hmset("user", map);
// 取出users中的Name,执行结果:[minxr]-->注意结果是一个泛型的List
// 第一个参数是存入redis中map对象的key,后面跟的是放入map中对象的key,后面的key可以是多个,是可变的
List<String> rsmap = jedis.hmget("user", "name", "age", "qq");
System.out.println(rsmap);
// 删除map中的某个键值
jedis.hdel("user", "age");
System.out.println(jedis.hmget("user", "age"));// 因为删除了,所以返回的是Null
System.out.println(jedis.hlen("user"));// 返回key为user的键中存放的值的个数2
System.out.println(jedis.exists("user"));// 是否存在key为user的记录,返回true
System.out.println(jedis.hkeys("user"));// 返回map对象中的所有key
System.out.println(jedis.hvals("user"));// 返回map对象中的所有value
Iterator<String> iter = jedis.hkeys("user").iterator();
while (iter.hasNext()) {
String key = iter.next();
System.out.println(key + ":" + jedis.hmget("user", key));
}
}
/**
* redis操作List集合
*/
public static void testList() {
// 开始前,先移除所有的内容
jedis.del("java framework");
System.out.println(jedis.lrange("java framework", 0, -1));
// 先向key java framework 中存放三条数据
jedis.lpush("java framework", "spring");
jedis.lpush("java framework", "struts");
jedis.lpush("java framework", "hibernate");
// 再取出所有数据jedis.lrange是按范围取出
// 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有
System.out.println(jedis.lrange("java framework", 0, -1));
jedis.del("java framework");
jedis.rpush("java framework", "spring");
jedis.rpush("java framework", "struts");
jedis.rpush("java framework", "hibernate");
System.out.println(jedis.lrange("java framework", 0, -1));
}
/**
* redis操作set集合
*
*/
public static void testSet() {
// 添加
jedis.sadd("user", "liuling");
jedis.sadd("user", "xinxin");
jedis.sadd("user", "ling");
jedis.sadd("user", "zhangxinxin");
jedis.sadd("user", "who");
// 删除
jedis.srem("user", "who");
System.out.println(jedis.smembers("user"));// 获取所有加入的value
System.out.println(jedis.sismember("user", "who"));// 判断who是否是user集合的元素
System.out.println(jedis.srandmember("user"));
System.out.println(jedis.scard("user"));// 返回集合的元素个数
}
/**
* redis排序
*/
public static void testSort() {
// jedis 排序
// 注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的)
jedis.del("a");// 先清除数据,再加入数据进行测试
jedis.rpush("a", "1");
jedis.lpush("a", "6");
jedis.lpush("a", "3");
jedis.lpush("a", "9");
System.out.println(jedis.lrange("a", 0, -1));
System.out.println(jedis.sort("a"));// [1,3,6,9] //输入排序后结果
System.out.println(jedis.lrange("a", 0, -1));
}
}
以上是关于redis相关的主要内容,如果未能解决你的问题,请参考以下文章