1、pipline的使用
#先打开一个redis的管道
#打开之后就可以进行发送请求和接受回应
with redis_conn._redis_client.pipeline() as pipeline:
#一个pipeline在被execute之前可以一直发各种请求,
#直到遇到第一个pipeline.execute(),这个函数把之前所有的请求的响应全部返回回来,存到一个list中
#delete + key 删除db中的这个key
pipeline.delete(bookid)
#lpop + listname 弹出list中的第一个数据
pipeline.lpop(dut_key)
#zrem + Zsetname + key 删除有序集合中的bookid这个value
pipeline.zrem('booking_list', bookid)
#这时候遇到第一个excute,就把上面的三个操作的结果返回,相当于把管道清理干净了
result1 = pipline.excute()
# result1 = [1,'eb919704-33dd-11ed-ba17-0242ac120005',1]
#下面的操作重新往管道里塞东西
#这些操作名和redis的基本差不多,不做详细介绍了
pipeline.hmset(bookid, book_info)
pipeline.zadd('booking_list', {bookid: cur_time_stamp})
pipeline.lpush(dut_key, bookid)
pipeline.expire(bookid, int(new_rest_time))
result2 = pipeline.execute()
# result2 = [true,1,1,true]
2、注意
不能直接print(pipeline.llen(listname))来求list的长度
必须用pipeline.execute()来获取返回值