package redis.test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.junit.Before;
import org.junit.Test;
/**
* Created by Tony
*/
public class JedisUtilTest {
JedisPool pool;
Jedis jedis;
@Before
public void setUp() {
pool = new JedisPool(new JedisPoolConfig(), "127.0.0.1");
jedis = pool.getResource();
// jedis.auth("password");
}
@Test
public void testGet() {
System.out.println(jedis.get("lu"));
}
/**
* Redis存储初级的字符串 CRUD
*/
@Test
public void testBasicString() {
// -----添加数据----------
jedis.set("name", "minxr");// 向key-->name中放入了value-->minxr
System.out.println(jedis.get("name"));// 执行结果:minxr
// -----修改数据-----------
// 1、在原来基础上修改
jedis.append("name", "jarorwar"); // 很直观,类似map 将jarorwar
// append到已经有的value之后
System.out.println(jedis.get("name"));// 执行结果:minxrjarorwar
// 2、直接覆盖原来的数据
jedis.set("name", "tony");
System.out.println(jedis.get("name"));// 执行结果:tony
// 删除key对应的记录
jedis.del("name");
System.out.println(jedis.get("name"));// 执行结果:null
/**
* mset相当于 jedis.set("name","minxr"); jedis.set("jarorwar","tony");
*/
jedis.mset("name", "minxr", "jarorwar", "tony");
System.out.println(jedis.mget("name", "jarorwar"));
}
/**
* jedis操作Map
*/
@Test
public void testMap() {
Map user = new HashMap();
user.put("name", "minxr");
user.put("pwd", "password");
jedis.hmset("user", user);
// 取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List
// 第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数
List 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 iter = jedis.hkeys("user").iterator();
while (iter.hasNext()) {
String key = iter.next();
System.out.println(key + ":" + jedis.hmget("user", key));
}
}
/**
* jedis操作List
*/
@Test
public 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操作Set
*/
@Test
public void testSet() {
// 添加
jedis.sadd("sname", "minxr");
jedis.sadd("sname", "jarorwar");
jedis.sadd("sname", "tony");
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
public void test() throws InterruptedException {
// keys中传入的可以用通配符
System.out.println(jedis.keys("*")); // 返回当前库中所有的key [sose, sanme, name,
// jarorwar, foo, sname, java
// framework, 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));
System.out.println(jedis.blpop(0, "a"));
}
}
package redis.test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.exceptions.JedisConnectionException;
public class FirstClient {
private static Jedis jedis = new Jedis("localhost");
public void testConn() {
try {
jedis.connect();
jedis.ping();
jedis.quit();
} catch (JedisConnectionException e) {
e.printStackTrace();
}
}
public void setTest() {
try {
//EXPIRE key seconds 为给定key设置生存时间。当key过期时,它会被自动删除。
jedis.expire("messages", 10);//10秒过期
//EXPIREAT EXPIREAT的作用和EXPIRE一样,都用于为key设置生存时间。不同在于EXPIREAT命令接受的时间参数是UNIX时间戳(unix timestamp)。
for (int i = 0; i < 100; i++) {
//jedis.set("key" + i, "value" + i);
jedis.rpush("messages", "value" + i);
}
} catch (Exception e) {
e.printStackTrace();
}
}
public void getTest() {
try {
for (int i = 0; i < 100; i++) {
//System.out.println(jedis.get("key" + i));
//System.out.println(jedis.lrange("messages", i, i));
//处于阻塞等待状态
System.out.println(jedis.blpop(0, "messages"));//接收了数据后,队列里就没有数据了
}
} catch (Exception e) {
e.printStackTrace();
}
}
public void detTest(){
jedis.del("messages");
}
public static void main(String[] args) {
FirstClient client = new FirstClient();
//client.setTest();
client.getTest();
//client.detTest();
System.exit(0);
}
}
package redis.test;
import java.util.List;
import redis.clients.jedis.Jedis;
/**
* 系统名称:XXXXXXXX(redis-test)
* 所属模块:XXXXXXXXXXXXXX
* 功能描述:XXXXXXXXXXXXXX
* 文件名:redis.test.RedisTest.java
* 版本信息:1.00
*
* 开发部门:XXXXX
* 创建者: Administrator
* 创建时间:2014-12-2 上午11:51:30
* 修改者: Administrator
* 修改时间:2014-12-2 上午11:51:30
*/
public class RedisTest {
/**
* @param args
*/
public static void main(String[] args) {
Jedis jedis = new Jedis("192.168.2.128", 6379, 0);
String value;
// 1. k-v存储
jedis.set("name", "helloword");
value = jedis.get("name");
System.out.println("1: " + value);
// 2. 将新增的值添加到旧值后面
jedis.append("name", " append new info,");
value = jedis.get("name");
System.out.println("2: " + value);
// 3. 删除key对应的记录
// jedis.del("name");
// value = jedis.get("name");
// System.out.println("3: " + value);
// 4. 批量设值
jedis.mset("name1", "minxr", "name2", "aaa");
System.out.println("4: " + jedis.mget("name1", "name2"));
// 5. 清空数据,所有的
// System.out.println(jedis.flushDB());
// 6. 截取value的值
System.out.println("6: " + jedis.getrange("name", 1, 3));
// 7.按通配符模糊查找符合条件的key
System.out.println("7: " + jedis.keys("*na*"));
// 8. 数据库大小
System.out.println("8: " + jedis.dbSize());
// 9. k-v存储,v表示的List(队列形式) //先进先出
jedis.del("messages");
jedis.rpush("messages", "how");
jedis.rpush("messages", "are");
jedis.rpush("messages", "you");
// 返回messages对应的集合长度
System.out.println("9: " + jedis.llen("messages"));
// 取数据,第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有
List values = jedis.lrange("messages", 0, 1);
System.out.println("9: " + values);
// 10. k-v存储,v表示的List(堆栈形式) //后进先出
jedis.del("desc");
jedis.lpush("desc", "1");
jedis.lpush("desc", "2");
jedis.lpush("desc", "3");
jedis.lpush("desc", "4");
// 数组长度
System.out.println("10: " + jedis.llen("desc"));
System.out.println("10: " + jedis.lrange("desc", 0, -1));
// 11. 取出库中所有的key
for (String a : jedis.keys("*")) {
System.out.println("======================");
System.out.println(a);
}
}
}