/** * * List操作 * 列表操作 * 可理解为数组操作 * 插入、删除数据按照一定规律排列的 * 元素可重复 * 适用于队列 * */ //在列表头部插入一个值one,当列表不存在时自动创建一个列表,key1为列表名 $redis->lpush("key1", "one"); //在列表尾部插入一个值two,当列表不存在时自动创建一个列表,key1为列表名 $redis->rPush("key1","two"); //将一个插入已存在的列表头部,列表不存在时操作无效 $redis->rPushx("key1","1"); //删除列表的第一个元素并返回列表和列表的第一个元素,当key1不存在或不是列表则返回false $redis->lPop('key1'); //删除列表的最后一个元素并返回列表和列表的最后一个元素,当key1不存在或不是列表则返回false $redis->rPop('key1'); //删除并或取列表的第一个元素,如果没有元素则会阻塞直到等待超时 $redis->blPop('asd', 10); //删除并或取列表的最后一个元素,如果没有元素则会阻塞直到等待超时 $ret = $redis->brPop('asd', 10); //移除列表key1中最后一个元素,将其插入另一个列表asd头部,并返回这个元素。若源列表没有元素则返回false $redis->rpoplpush('key1', 'asd'); //移除列表key1中最后一个元素,将其插入另一个列表asd头部,并返回这个元素。如果列表没有元素则会阻塞列表直到超时,超时返回false。 $ret = $redis->brpoplpush('key1', 'asd', 10); //返回列表长度 $redis->lLen('key1'); //通过索引 (也就是下标key) 获取列表中的元素,如果没有该索引,则返回false。 $redis->lindex('key1', 0); //通过索引修改列表中元素的值,如果没有该索引,则返回false。 $redis->lSet('key1', 2, '1'); //在列表key1中指定元素six前面或后面插入元素。若指定元素不在列表中,或列表不存在时,不执行任何操作 //Redis::AFTER插入元素后面 Redis::BEFORE插入元素前面 //返回值:插入成功返回插入后列表元素个数,若key1不存在返回0,若key1不是列表返回false $redis->lInsert('key1', Redis::BEFORE, 'one', '1'); //根据第三个参数(count),删除掉相对的value //count > 0 : 从表头开始向表尾搜索,移除与value相等的元素,数量为count。 //count < 0 : 从表尾开始向表头搜索,移除与value相等的元素,数量为count的绝对值。 //count = 0 : 移除表中所有与value相等的值。 //返回实际删除元素个数 $redis->lrem('key1', '1', -2); //对一个列表进行截取,只保留指定区间 (如:下标1到10) 的元素,其他元素都删除。成功返回true。 $redis->ltrim('key1', 1, 10); // 获取存储的数据并输出列表下标0到5的数据 // 0为开始查询的列表里的第一个元素,-1则为最后一个元素 // 5代表查询5条数据,当5为-1时则查看所有数据, $redis->lrange("key1", 0 ,5);