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();//销毁连接池中的所有连接

}

}

相关推荐