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


Java Update.inc方法代碼示例

本文整理匯總了Java中org.springframework.data.mongodb.core.query.Update.inc方法的典型用法代碼示例。如果您正苦於以下問題:Java Update.inc方法的具體用法?Java Update.inc怎麽用?Java Update.inc使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.springframework.data.mongodb.core.query.Update的用法示例。


在下文中一共展示了Update.inc方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getNextSequenceId

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
public Long getNextSequenceId(String key) {
    /** Get <code>Sequence</code> object by collection name*/
    Query query = new Query(Criteria.where("id").is(key));

    /** Increase field sequence by 1*/
    Update update = new Update();
    update.inc("sequence", 1);

    // указываем опцию, что нужно возвращать измененный объект
    /** Set option about returning new object*/
    FindAndModifyOptions options = new FindAndModifyOptions();
    options.returnNew(true);

    Sequence sequence = mongoOperations.findAndModify(query, update, options, Sequence.class);

    // if no sequence set id value 'key'
    if (sequence == null) {
        sequence = setSequenceId(key, 1L);
    }

    return sequence.getCurrent();
}
 
開發者ID:chirkovd,項目名稱:spring-es-sample,代碼行數:23,代碼來源:SequenceService.java

示例2: getID

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
@Override
public int getID(String indexKey, int defaultIndex) {
	synchronized (IDGeneratorDaoImpl.class) {
		if (!this.mongoBaseDao.collectionExists(IDGenerator.class)) {
			this.mongoBaseDao.createCollection(IDGenerator.class);
		}
		Query query = new Query();
		query.addCriteria(new Criteria("id").is(indexKey));
		Update update = new Update();
		update.inc("index", 1);
		IDGenerator idGenerator = this.mongoBaseDao.findAndModify(query, update, IDGenerator.class);
		if (idGenerator == null) {// 如果不存在,則新增
			idGenerator = new IDGenerator(indexKey, defaultIndex);
			this.mongoBaseDao.save(idGenerator);
		}
		return idGenerator.getIndex();
	}
}
 
開發者ID:amao12580,項目名稱:RSSReader,代碼行數:19,代碼來源:IDGeneratorDaoImpl.java

示例3: updateCashBalance

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
public boolean updateCashBalance(String userId, double cashBalance) {
    Update updateOp = new Update();
    updateOp.inc("amountToBePaid", cashBalance);
    final Query query = new Query();
    query.addCriteria(where("_id").is(userId));
    WriteResult writeResult =  mongoTemplate.updateMulti(query, updateOp, User.class);
    return writeResult.getN() == 1;
}
 
開發者ID:srinikandula,項目名稱:mybus,代碼行數:9,代碼來源:UserMongoDAO.java

示例4: nextSequeceNumber

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
private ShipmentSequence nextSequeceNumber(ShipmentType shipmentType) {
    ShipmentSequence shipmentSequence = null;
    if(shipmentSequenceDAO.findByShipmentCode(shipmentType.getKey()) == null){
        shipmentSequence = shipmentSequenceDAO.save(new ShipmentSequence(shipmentType));
    } else {
        Update updateOp = new Update();
        updateOp.inc("nextNumber", 1);
        final Query query = new Query();
        query.addCriteria(where("shipmentCode").is(shipmentType.getKey()));
        WriteResult writeResult =  mongoTemplate.updateMulti(query, updateOp, ShipmentSequence.class);
        if(writeResult.getN() == 1){
            shipmentSequence = shipmentSequenceDAO.findByShipmentCode(shipmentType.getKey());
        } else {
            throw new IllegalStateException("next number failed");
        }
    }
    return shipmentSequence;
}
 
開發者ID:srinikandula,項目名稱:mybus,代碼行數:19,代碼來源:ShipmentSequenceManager.java

示例5: getNextSequenceId

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
@Override
public long getNextSequenceId(String key) {
    //get sequence id
    Query query = new Query(Criteria.where("_id").is(key));

    //increase sequence id by 1
    Update update = new Update();
    update.inc("seq", 1);

    //return new increased id
    FindAndModifyOptions options = new FindAndModifyOptions();
    options.returnNew(true);

    SequenceId seqId =
            mongoOperation.findAndModify(query, update, options, SequenceId.class);

    //if no id, throws SequenceException
    if (seqId == null) {
        log.error("Unable to get sequence id for key: {}", key);
        throw new SequenceException("Unable to get sequence id for key: " + key);
    }

    log.debug("Next sequendId: {}", seqId);
    return seqId.getSeq();
}
 
開發者ID:edwise,項目名稱:complete-spring-project,代碼行數:26,代碼來源:SequenceIdRepositoryImpl.java

示例6: newRevisionId

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
public Integer newRevisionId() {
	Query query = new Query();
	query.addCriteria(Criteria.where("platformVersionId").is(PlatformServerConfig.PLATFORM_VERSION));
	Update update = new Update();
	update.inc("currentTopRevisionId", 1);
	PlatformVersions platformVersions = platformVersionsDao.update(query, update);
	return platformVersions.getCurrentTopRevisionId();
}
 
開發者ID:shenan4321,項目名稱:BIMplatform,代碼行數:9,代碼來源:CatalogServiceImpl.java

示例7: updateSequence

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
public void updateSequence(String key, Long delta) {
    Query query = new Query(Criteria.where("id").is(key));
    Update update = new Update();
    update.inc("sequence", delta);

    FindAndModifyOptions options = new FindAndModifyOptions();
    options.upsert(true);

    mongoOperations.findAndModify(query, update, options, Sequence.class);
}
 
開發者ID:chirkovd,項目名稱:spring-es-sample,代碼行數:11,代碼來源:SequenceService.java

示例8: getNextSequenceId

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
@Override
public int getNextSequenceId(String key) throws DataAccessException {
	
	//get sequence id
	Query query = new Query(Criteria.where("id").is(key));

	//increase sequence id by 1
	Update update = new Update();
	update.inc("seq", 1);

	//return new increased id
	FindAndModifyOptions options = new FindAndModifyOptions();
	options.returnNew(true);

	//this is the magic happened.
	Sequence seqId = mongoOperations.findAndModify(query, update, options, Sequence.class);

	// if no id, throws SequenceException
	// optional, just a way to tell user when the sequence id is failed to
	// generate.
	if (seqId == null) {
		seqId = new Sequence();
		seqId.setId(key);
		seqId.setSeq(1);
		mongoOperations.insert(seqId);
		return 1;
	}else{
		return seqId.getSeq();
	}

}
 
開發者ID:quebic-source,項目名稱:microservices-sample-project,代碼行數:32,代碼來源:SequenceDaoImpl.java

示例9: getNextSequence

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
@Override
public SysSequence getNextSequence(String colName) {
    Query query = new Query(Criteria.where("colName").is(colName));

    Update update = new Update();
    update.inc("sequence",1);

    FindAndModifyOptions options = new FindAndModifyOptions();
    options.returnNew(true);

    return mongoTemplate.findAndModify(query, update, options, SysSequence.class, Constant.COL_NAME_SYS_SEQUENCE);
}
 
開發者ID:fengzhizi715,項目名稱:ProxyPool,代碼行數:13,代碼來源:CommonDaoImpl.java

示例10: getNextSequenceId

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
@Override
public long getNextSequenceId(String key) throws SequenceException {
	
  //get sequence id
  Query query = new Query(Criteria.where("_id").is(key));

  //increase sequence id by 1
  Update update = new Update();
  update.inc("seq", 1);

  //return new increased id
  FindAndModifyOptions options = new FindAndModifyOptions();
  options.returnNew(true);

  //this is the magic happened.
  SequenceId seqId = 
           mongoOperation.findAndModify(query, update, options, SequenceId.class);

  //if no id, throws SequenceException
         //optional, just a way to tell user when the sequence id is failed to generate.
  if (seqId == null) {
	throw new SequenceException("Unable to get sequence id for key : " + key);
  }

  return seqId.getSeq();

}
 
開發者ID:lawrencelai,項目名稱:Oriole,代碼行數:28,代碼來源:SequenceDaoImpl.java

示例11: testUpdateUser

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
/**
 * 更新用戶數據
 */
@Test
public void testUpdateUser() {
	// update(query,update,class)
	// Query query:需要更新哪些用戶,查詢參數
	// Update update:操作符,需要對數據做什麽更新
	// Class class:實體類

	// 更新age大於24的用戶信息
	Query query = new Query();
	query.addCriteria(where("age").gt(24));

	Update update = new Update();
	// age值加2
	update.inc("age", 2);
	// update.set("name", "zhangsan"); 直接賦值
	// update.unset("name"); 刪去字段
	// update.push("interest", "java"); 把java追加到interest裏麵,interest一定得是數組
	// update.pushAll("interest", new String[]{".net","mq"})
	// 用法同push,隻是pushAll一定可以追加多個值到一個數組字段內
	// update.pull("interest", "study"); 作用和push相反,從interest字段中刪除一個等於value的值
	// update.pullAll("interest", new String[]{"sing","dota"})作用和pushAll相反
	// update.addToSet("interest", "study") 把一個值添加到數組字段中,而且隻有當這個值不在數組內的時候才增加
	// update.rename("oldName", "newName") 字段重命名

	// 隻更新第一條記錄,age加2,name值更新為zhangsan
	mongoTemplate.updateFirst(query, new Update().inc("age", 2).set("name", "zhangsan"), User.class);

	// 批量更新,更新所有查詢到的數據
	mongoTemplate.updateMulti(query, update, User.class);

}
 
開發者ID:dreajay,項目名稱:jcode,代碼行數:35,代碼來源:MongoSpringTest.java

示例12: getNextSequenceId

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
@Override
public String getNextSequenceId(String key) throws SequenceException {

	// get sequence id
	Query query = new Query(Criteria.where("_id").is(key));

	// increase sequence id by 1
	Update update = new Update();
	update.inc("seq", 1);

	// return new increased id
	FindAndModifyOptions options = new FindAndModifyOptions();
	options.returnNew(true);

	ApplicationContext ctx = new AnnotationConfigApplicationContext(SpringMongoConfig.class);
	MongoOperations mongoOperation = (MongoOperations) ctx.getBean("mongoTemplate");

	if (mongoOperation != null) {
		System.out.println(" Mongo Operations Found ");

		// this is the magic happened.
		SequenceId seqId = mongoOperation.findAndModify(query, update, options, SequenceId.class);

		// if no id, throws SequenceException
		// optional, just a way to tell user when the sequence id is failed to
		// generate.
		if (seqId == null) {
			throw new SequenceException("Unable to get sequence id for key : " + key);
		}

		return seqId.getSeq();
	} else {
		System.out.println("No Mongo Operations Object .. returning 100");
		return "100";
	}
}
 
開發者ID:CityOfNewYork,項目名稱:CROL-WebApp,代碼行數:37,代碼來源:SequenceDaoImpl.java

示例13: updateCashBalance

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
public boolean updateCashBalance(String officeId, double cashBalance) {
    Update updateOp = new Update();
    updateOp.inc("cashBalance", cashBalance);
    final Query query = new Query();
    query.addCriteria(where("_id").is(officeId));
    WriteResult writeResult =  mongoTemplate.updateMulti(query, updateOp, BranchOffice.class);
    return writeResult.getN() == 1;
}
 
開發者ID:srinikandula,項目名稱:mybus,代碼行數:9,代碼來源:BranchOfficeMongoDAO.java

示例14: getNextSequence

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
/**
 * 차기 SEQUENCE를 가져온다.
 *
 * @param name 게시판 ID
 * @return 다음 글번호
 */
public Integer getNextSequence(String name) {
	
	Integer nextSeq = 1;
	
	Query query = new Query();
	query.addCriteria(Criteria.where("name").is(name));
	
	Update update = new Update();
	update.inc("seq", 1);
	
	FindAndModifyOptions options = new FindAndModifyOptions();
	options.returnNew(true);
	
	Sequence sequence = mongoTemplate.findAndModify(query, update, options, Sequence.class);
	
	if (sequence == null) {
		Sequence newSequence = new Sequence();
		newSequence.setName(name);
		sequenceRepository.save(newSequence);
		log.debug("sequence is Null. Insert new Sequence.");
		
		return nextSeq;
	} else {
		nextSeq = sequence.getSeq();
		return nextSeq;
	}
}
 
開發者ID:JakduK,項目名稱:jakduk-api,代碼行數:34,代碼來源:CommonService.java

示例15: increaseFieldValue

import org.springframework.data.mongodb.core.query.Update; //導入方法依賴的package包/類
@Override
public <T> void increaseFieldValue(Class<T> entityName, String field, Integer defaultValue, Serializable id) {
	Query query = Query.query(Criteria.where("_id").is(id));
	Update update = new Update();
	update.inc(field, defaultValue);
	operations.updateFirst(query, update, entityName);
}
 
開發者ID:howsun,項目名稱:howsun-javaee-framework,代碼行數:8,代碼來源:MongoGenericDao.java


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