Jedis几个简单测试例子

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); } } }



你可能感兴趣的:(Redis,Java)