本文整理匯總了Java中redis.clients.jedis.Transaction.zrem方法的典型用法代碼示例。如果您正苦於以下問題:Java Transaction.zrem方法的具體用法?Java Transaction.zrem怎麽用?Java Transaction.zrem使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類redis.clients.jedis.Transaction
的用法示例。
在下文中一共展示了Transaction.zrem方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: updateQueuedJob
import redis.clients.jedis.Transaction; //導入方法依賴的package包/類
@Override
public synchronized void updateQueuedJob(int jobId, JSONObject newJob) {
try (Jedis jedis = jedisPool.getResource()) {
jedis.select(redisDBIndex);
if (jedis.zcard(queue) > 0) {
Optional<Double> score = null;
Set<Tuple> tuples = jedis.zrangeByScoreWithScores(queue, 0, Double.MAX_VALUE);
String old = null;
for(Tuple data : tuples) {
JSONObject detail = JSONObject.parseObject(data.getElement());
int id = detail.getIntValue(ScheduledConstants.JOB_ID);
if(id == jobId) {
score = Optional.ofNullable(data.getScore());
old = data.getElement();
break;
}
}
if(score.isPresent()){
Transaction tx = jedis.multi();
tx.zrem(queue, old);
tx.zadd(queue, score.get(), newJob.toJSONString());
tx.exec();
}
}
}
}
示例2: remove
import redis.clients.jedis.Transaction; //導入方法依賴的package包/類
/**
* Remove a message completely.
*
* @param msg
* @return
*/
protected boolean remove(IQueueMessage<ID, DATA> msg) {
if (isEphemeralDisabled()) {
return true;
}
try (Jedis jedis = jedisPool.getResource()) {
Transaction jt = jedis.multi();
byte[] field = msg.qId().toString().getBytes(QueueUtils.UTF8);
Response<Long> response = jt.hdel(redisHashName, field);
jt.zrem(redisSortedSetName, field);
jt.exec();
Long value = response.get();
return value != null && value.longValue() > 1;
}
}
示例3: prioritize
import redis.clients.jedis.Transaction; //導入方法依賴的package包/類
@Override
public synchronized void prioritize(int jobId) {
try (Jedis jedis = jedisPool.getResource()) {
jedis.select(redisDBIndex);
if (jedis.zcard(queue) > 0) {
double minScore = -1;
String selectedMember = null;
Set<Tuple> tuples = jedis.zrangeByScoreWithScores(queue, 0, Double.MAX_VALUE);
for(Tuple data : tuples) {
JSONObject detail = JSONObject.parseObject(data.getElement());
int id = detail.getIntValue(ScheduledConstants.JOB_ID);
// retrieve minimum score
if(minScore < 0) {
minScore = data.getScore();
}
if(id == jobId) {
selectedMember = data.getElement();
break;
}
}
Transaction tx = jedis.multi();
tx.zrem(queue, selectedMember);
double newScore = minScore - 1;
tx.zadd(queue, newScore, selectedMember);
tx.exec();
}
}
}
示例4: storeOld
import redis.clients.jedis.Transaction; //導入方法依賴的package包/類
/**
* Re-store an old message (called by {@link #requeue(IQueueMessage)} or
* {@link #requeueSilent(IQueueMessage)}.
*
* @param msg
* @return
*/
protected boolean storeOld(IQueueMessage<ID, DATA> msg) {
try (Jedis jedis = jedisPool.getResource()) {
Transaction jt = jedis.multi();
byte[] field = msg.qId().toString().getBytes(QueueUtils.UTF8);
byte[] data = serialize(msg);
jt.hset(redisHashName, field, data);
jt.rpush(redisListName, field);
jt.zrem(redisSortedSetName, field);
jt.exec();
return true;
}
}