List: 它的數據結構和java中的linkedlist是一樣的,是一個雙向循環鏈表。在里面預先插入了3840000條記錄。服務器配置,pc機,為Redis分配了1g內存 2g vm。
1.插入:62ms,lpush rpush一樣。
2.刪除:lpop,rpop 63ms。
刪除第一個元素 lrem(key, value, 1) 63ms 刪除最后一個元素 780ms。但刪除最后一個元素可以使用lrem(key, value, -1)這樣也是63ms。使用lrem(key, value, 0)刪除所有等于value值的元素780ms,每次都要遍歷一遍。不推薦使用。
.
2.查詢:lindex第一個元素,70ms,lindex最后一個元素300ms。反之用-1亦然。
lrange中間的10000個元素 250ms
3.大小:size一把,63ms。應該有專門存儲了list大小。
4.賦值:lset 第一個元素63ms。 lset最后一個元素280ms
我使用時用的是lpush,通常經常用到的會是第一頁,會查詢,刪除的快一些。使用時,建議對List使用限長。可以通過trim實現。
另外在使用list時,可以加個時間撮,比如201012。這樣12月份的數據就會存在這個List中。而10月份之前的可以存DB或者清除。
另外Redis提供了set和sortset,但是沒有LinkedHashSet。我們可以用Redis自己實現一個。

public boolean add(String name, String id, Object e)
{
boolean notExist = redisTemplate.setnx(name+id, 2);

if(notExist)
{
redisTemplate.lpush(name, id);
}
return notExist;
}



public boolean remove(String name, String id)
{

if(redisTemplate.delKey(name+id))
{
return redisTemplate.lrem(name, e, 1) >0 ;
}
return false;
}