當前位置: 首頁>>代碼示例>>Java>>正文


Java Transaction.zrem方法代碼示例

本文整理匯總了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();
   			}
   		}
   	}
}
 
開發者ID:shirdrn,項目名稱:scheduled,代碼行數:27,代碼來源:RedisJobQueueingService.java

示例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;
    }
}
 
開發者ID:DDTH,項目名稱:ddth-queue,代碼行數:23,代碼來源:RedisQueue.java

示例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();
		}
	}
}
 
開發者ID:shirdrn,項目名稱:scheduled,代碼行數:30,代碼來源:RedisJobQueueingService.java

示例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;
    }
}
 
開發者ID:DDTH,項目名稱:ddth-queue,代碼行數:22,代碼來源:RedisQueue.java


注:本文中的redis.clients.jedis.Transaction.zrem方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。