redis缓存mysql的操作_Redis缓存数据库常见操作

Jedis的最为常见的操作。主要包括常用的列表(list)、集合(set)、有序集合(sorted set)、哈希表(hash)等数据结构,以及其他特性支持。

. 使用list:

可以使用列表模拟队列(queue)、堆栈(stack),并且支持双向的操作(L或者R)。

1. 右边入队:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.rpush("userList", "James");

2. 左边出队:右边出栈(rpop),即为对堆栈的操作。

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.lpop("userList");

3. 返回列表范围:从0开始,到最后一个(-1) [包含]

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

List userList = jedis.lrange("userList", 0, -1);

Redis的TopN操作,即使用list完成:lrange

4. 删除:使用key

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.del("userList");

5. 设置:位置1处为新值

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.lset("userList", 1, "Nick Xu");

6. 返回长度:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Long size = jedis.llen("userList");

7. 进行裁剪:包含

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.ltrim("userList", 1, 2);

. 使用set:和列表不同,集合中的元素是无序的,因此元素也不能重复。

1. 添加到set:可一次添加多个

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.sadd("fruit", "apple");

jedis.sadd("fruit", "pear", "watermelon");

jedis.sadd("fruit", "apple");

2. 遍历集合:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Set fruit = jedis.smembers("fruit");

3. 移除元素:remove

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.srem("fruit", "pear");

4. 返回长度:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Long size = jedis.scard("fruit");

5. 是否包含:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Boolean isMember = jedis.sismember("fruit", "pear");

6. 集合的操作:包括集合的交运算(sinter)、差集(sdiff)、并集(sunion)

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.sadd("food", "bread", "milk");

Set fruitFood = jedis.sunion("fruit", "food");

. 使用sorted set:有序集合在集合的基础上,增加了一个用于排序的参数。

1. 有序集合:根据“第二个参数”进行排序。

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.zadd("user", 22, "James");

2. 再次添加:元素相同时,更新为当前的权重。

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.zadd("user", 24, "James");

3. zset的范围:找到从0到-1的所有元素。

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Set user = jedis.zrange("user", 0, -1);

4. 说明:我们可能还有一个疑虑,集合是怎么做到有序的呢?

实际上,上述user的数据类型为java.util.LinkedHashSet

. 使用hash:

1. 存放数据:使用HashMap

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Map  capital = new HashMap();

capital.put("shannxi", "xi'an");

...

jedis.hmset("capital", capital);

2. 获取数据:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

List cities = jedis.hmget("capital", "shannxi", "shanghai");

. 其他操作:

1. 对key的操作:

@ 对key的模糊查询:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Set keys = jedis.keys("*");

Set keys = jedis.keys("user.userid.*");

@ 删除key:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.del("city");

@ 是否存在:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Boolean isExists = jedis.exists("user.userid.14101");

2. 失效时间:

@ expire:时间为5s

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.setex("user.userid.14101", 5, "James");

@ 存活时间(ttl):time to live

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Long seconds = jedis.ttl("user.userid.14101");

@ 去掉key的expire设置:不再有失效时间

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.persist("user.userid.14101");

3. 自增的整型:

@ int类型采用string类型的方式存储:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.set("amount", 100 + "");

@ 递增或递减:incr()/decr()

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.incr("amount");

@ 增加或减少:incrBy()/decrBy()

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.incrBy("amount", 20);

4. 数据清空:

@ 清空当前db:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.flushDB();

@ 清空所有db:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

jedis.flushAll();

5. 事务支持:

@ 获取事务:

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

Transaction tx = jedis.multi();

@ 批量操作:tx采用和jedis一致的API接口

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

for(int i = 0;i 

tx.set("key" + i, "value" + i);

System.out.println("--------key" + i);

Thread.sleep(1000);

}

@ 执行事务:针对每一个操作,返回其执行的结果,成功即为Ok

Java代码  3478255a5af373ac815fb71bfdf4cebf.png

List results = tx.exec();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值