redis本身不支持批量删除key.可以借助jedis客户端,shell和lua脚本来实现
下面将逐一介绍这三种方式
比如删除前缀为 “mykey” 的所有key
1. shell脚本
redis-cli KEYS "mykey*" | xargs redis-cli DEL
2. lua 脚本 windows客户端下可以使用这种
redis-cli eval "redis.call('del', unpack(redis.call('keys','mykey*')))" 0
3.jedis 客户端批量删除key ,java客户端适用这种
jedis客户端并没有提供批量删除key的方法,但是可以通过另外一种思路来实现
/**
* 删除key,可以是一个,也可以是多个key
* @param keys
*/
public synchronized static void deleteKey(String ... keys ){
getJedis().del(keys);
}
/**
* 删除匹配的key<br>
* 如以my为前缀的则 参数为"my*"
* @param key
*/
public synchronized static void deleteKeys(String pattern){
//列出所有匹配的key
Set<String> keySet = getJedis().keys(pattern);
if(keySet == null || keySet.size()<=0){
return;
}
String keyArr[] = new String[keySet.size()];
int i =0;
for (String keys : keySet) {
keyArr[i] = keys;
i++;
}
deleteKey(keyArr);
}
/**
* 删除前缀为{参数}的所有key<br>
* @param prefix
*/
public synchronized static void deleteKeyByPrefix(String prefix){
deleteKeys(prefix+"*");
}
/**
* 删除包含{参数}的所有key<br>
* @param contain
*/
public synchronized static void deleteKeyByContain(String contain){
deleteKeys("*"+contain+"*");
}
/**
* 删除当前中所有key
*/
public synchronized static void flushdb(){
getJedis().flushDB();
}
当前数据库:flushdb
所有:flushall
本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。