JAVA操作redis
memercached与redis的俩者重点区别
1、Memcached是多线程,非阻塞IO复用的网络模型
Redis使用单线程的IO复用模型
2、Memcached只支持简单keyvalue存取数据
Redis除key/value之外,还支持list,set,sortedset,hash等众多数据结构
3、Memcached不支持统计和key的正则表达式查询。
Redis支持简单的统计,和key的正则表达式查询。
importorg.junit.After;
importorg.junit.Before;
importorg.junit.Test;
importredis.clients.jedis.Jedis;
importredis.clients.jedis.JedisPool;
importredis.clients.jedis.JedisPoolConfig;
importjavax.sound.midi.Soundbank;
importjava.util.*;
/**
*@author:Tom
*Time:2012.5.716:23:15
*/
publicclassRedisTest{
JedisPoolpool;
Jedisjedis;
@Before
publicvoidsetUp(){
pool=newJedisPool(newJedisPoolConfig(),"172.16.100.184");
jedis=pool.getResource();
jedis.auth("password");
}
/**
*Redis存储初级的字符串
*CRUD
*/
@Test
publicvoidtestBasicString(){
//-----添加数据----------
jedis.set("name","minxr");//向key-->name中放入了value-->minxr
System.out.println(jedis.get("name"));//执行结果:minxr
//-----修改数据-----------
//1、在原来基础上修改
jedis.append("name","jarorwar");//很直观,类似map将jarorwarappend到已经有的value之后
System.out.println(jedis.get("name"));//执行结果:minxrjarorwar
//2、直接覆盖原来的数据
jedis.set("name","闵晓荣");
System.out.println(jedis.get("name"));//执行结果:闵晓荣
//删除key对应的记录
jedis.del("name");
System.out.println(jedis.get("name"));//执行结果:null
/**
*mset相当于
*jedis.set("name","minxr");
*jedis.set("jarorwar","闵晓荣");
*/
jedis.mset("name","minxr","jarorwar","闵晓荣");
System.out.println(jedis.mget("name","jarorwar"));
}
/**
*jedis操作Map
*/
@Test
publicvoidtestMap(){
Map<String,String>user=newHashMap<String,String>();
user.put("name","minxr");
user.put("pwd","password");
jedis.hmset("user",user);
//取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List
//第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数
List<String>rsmap=jedis.hmget("user","name");
System.out.println(rsmap);
//删除map中的某个键值
//jedis.hdel("user","pwd");
System.out.println(jedis.hmget("user","pwd"));//因为删除了,所以返回的是null
System.out.println(jedis.hlen("user"));//返回key为user的键中存放的值的个数1
System.out.println(jedis.exists("user"));//是否存在key为user的记录返回true
System.out.println(jedis.hkeys("user"));//返回map对象中的所有key[pwd,name]
System.out.println(jedis.hvals("user"));//返回map对象中的所有value[minxr,password]
Iterator<String>iter=jedis.hkeys("user").iterator();
while(iter.hasNext()){
Stringkey=iter.next();
System.out.println(key+":"+jedis.hmget("user",key));
}
}
/**
*jedis操作List
*/
@Test
publicvoidtestList(){
//开始前,先移除所有的内容
jedis.del("javaframework");
System.out.println(jedis.lrange("javaframework",0,-1));
//先向keyjavaframework中存放三条数据
jedis.lpush("javaframework","spring");
jedis.lpush("javaframework","struts");
jedis.lpush("javaframework","hibernate");
//再取出所有数据jedis.lrange是按范围取出,
//第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度-1表示取得所有
System.out.println(jedis.lrange("javaframework",0,-1));
}
/**
*jedis操作Set
*/
@Test
publicvoidtestSet(){
//添加
jedis.sadd("sname","minxr");
jedis.sadd("sname","jarorwar");
jedis.sadd("sname","闵晓荣");
jedis.sadd("sanme","noname");
//移除noname
jedis.srem("sname","noname");
System.out.println(jedis.smembers("sname"));//获取所有加入的value
System.out.println(jedis.sismember("sname","minxr"));//判断minxr是否是sname集合的元素
System.out.println(jedis.srandmember("sname"));
System.out.println(jedis.scard("sname"));//返回集合的元素个数
}
@Test
publicvoidtest()throwsInterruptedException{
//keys中传入的可以用通配符
System.out.println(jedis.keys("*"));//返回当前库中所有的key[sose,sanme,name,jarorwar,foo,sname,javaframework,user,braand]
System.out.println(jedis.keys("*name"));//返回的sname[sname,name]
System.out.println(jedis.del("sanmdde"));//删除key为sanmdde的对象删除成功返回1删除失败(或者不存在)返回0
System.out.println(jedis.ttl("sname"));//返回给定key的有效时间,如果是-1则表示永远有效
jedis.setex("timekey",10,"min");//通过此方法,可以指定key的存活(有效时间)时间为秒
Thread.sleep(5000);//睡眠5秒后,剩余时间将为<=5
System.out.println(jedis.ttl("timekey"));//输出结果为5
jedis.setex("timekey",1,"min");//设为1后,下面再看剩余时间就是1了
System.out.println(jedis.ttl("timekey"));//输出结果为1
System.out.println(jedis.exists("key"));//检查key是否存在
System.out.println(jedis.rename("timekey","time"));
System.out.println(jedis.get("timekey"));//因为移除,返回为null
System.out.println(jedis.get("time"));//因为将timekey重命名为time所以可以取得值min
//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));//[9,3,6,1]
System.out.println(jedis.sort("a"));//[1,3,6,9]//输入排序后结果
System.out.println(jedis.lrange("a",0,-1));
}
@After
publicvoiddestory(){
pool.returnResource(jedis);//使用完之后将连接返回到连接池中
pool.destroy();//销毁连接池中的所有连接
}
}