", "struts");
jedis.rpush("java framework", "hibernate");
//再取出所有数据jedis.lrange是按范围取出 第一个是key 第二个是其实位置 第三个是结束位置
System.out.println(jedis.lrange("java framework", 0, -1));
}
/**
* 操作Set
*/
@Test
public void testSet(){
jedis.sadd("haha", "why");
jedis.sadd("haha", "you");
jedis.sadd("haha", "so");
jedis.sadd("haha", "diao");
jedis.sadd("haha", "?");
//移除
jedis.srem("haha", "?");
System.out.println("判断?是不是haha集合的元素:"+jedis.sismember("haha", "?"));
System.out.println("获取所有加入的value:"+jedis.smembers("haha"));
System.out.println("返回给定集合名的一个随机的value:"+jedis.srandmember("haha"));
System.out.println("返回集合的元素个数:"+jedis.scard("haha"));
}
/**
* redis 操作map
*/
@Test
public void testmap(){
Map map = new HashMap();
map.put("name", "小露");
map.put("sex", "男");
map.put("email", "haha@fcs.com");
jedis.hmset("user", map);//相当于给map再取一个名字
List rsmap = jedis.hmget("user", "name","sex");//后面是一个可变参数列表 去某个map中的一些key代表的值
System.out.println(rsmap);
//删除map中的某个键值
jedis.hdel("user", "email");
System.out.println("删除后----email"+jedis.hmget("user", "email"));
System.out.println("是否存在key为user的记录:"+jedis.exists("user"));
System.out.println("key为user的map中存放的值的个数:"+jedis.hlen("user"));
System.out.println("返回map对象中所有的key:"+jedis.hkeys("user"));
System.out.println("返回map对象中所有的value:"+jedis.hvals("user"));
//使用迭代器
Iterator iter = jedis.hkeys("user").iterator();
System.out.println("***************使用迭代器***************");
while(iter.hasNext()){
String key = iter.next();//每次向后越过一个对象
System.out.println(key+":"+jedis.hmget("user", key));//迭代key 根据key再取值value
}
}
/**
* 这里在前面执行完之后直接再去拿值 试试这些进驻内存的数据是否还在
* 可以把服务器端关掉再重启 再直接运行这个方法看看
* 如果还有数据就说明该数据库自动完成了持久化 它有默认的持久化机制
*/
@Test
public void testNoSet(){
Iterator iter = jedis.hkeys("user").iterator();
System.out.println("***************使用迭代器***************");
while(iter.hasNext()){
String key = iter.next();//每次向后越过一个对象
System.out.println(key+":"+jedis.hmget("user", key));//迭代key 根据key再取值value
}
}
// @AfterClass 测试整个类时可以用 会关闭服务器端程序
// public static void close(){
// jedis.shutdown();//不能用@After 不然每次执行完一个方法都会关闭服务器
// System.out.println("连接已关闭.....");
// }
}
这时候可以看到cmd中有一些日志记录:(这就是它默认的持久化机制,可以在redis.
windows.conf配置文件中查看)
[3972] 01 Dec 13:59:04.073 * 1 changes in 900 seconds. Saving...
[3972] 01 Dec 13:59:04.229 # fork operation complete
[3972] 01 Dec 13:59:04.229 * Background saving terminated with success
[3972] 01 Dec 14:20:05.127 * 1 changes in 900 seconds. Saving...
[3972] 01 Dec 14:20:05.267 # fork operation complete
[3972] 01 Dec 14:20:05.267 * Background saving terminated with success
[3972] 01 Dec 14:35:06.074 * 1 changes in 900 seconds. Saving...
[3972] 01 Dec 14:35:06.204 # fork operation complete
[3972] 01 Dec 14:35:06.224 * Background saving terminated with success
哎,先到这吧。。。。
|