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


Java Criteria類代碼示例

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


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

示例1: queryPage

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
@Override
public Page<User> queryPage(SysRole role, UserQueryRequest queryRequest) {
	int start = queryRequest.getStart();
	int limit = queryRequest.getLimit();
	Query query = new Query();
	query.addCriteria(Criteria.where("roles").in(role));
	if (!StringUtils.isEmpty(queryRequest.getUsername())) {
		query.addCriteria(Criteria.where("username").regex(queryRequest.getUsername()));
	}
	query.addCriteria(Criteria.where("deleted").ne(true));

	PageRequest pageable = new PageRequest(start, limit, new Sort(Sort.Direction.DESC, "username"));
	query.with(pageable);
	long count = mongoTemplate.count(query, User.class);
	List<User> list = mongoTemplate.find(query, User.class);

	return new PageImpl<>(list, pageable, count);
}
 
開發者ID:melthaw,項目名稱:spring-backend-boilerplate,代碼行數:19,代碼來源:UserRepositoryImpl.java

示例2: getMyRepositoryPosts

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
/** 자기가 진행중인 저장소의 글을 검색함.
 * @param privateAndMassageTags
 * @param search
 * @param sort
 * @param page
 * @param size
 * @return
 */
public List<Post> getMyRepositoryPosts(List<String> privateAndMassageTags, String search, 
		String sort, int page,int size) {
	Criteria criteria = new Criteria();

	criteria.and("tags").in(privateAndMassageTags);

	if (search != null)
		criteria.andOperator(new Criteria().orOperator(
				Criteria.where("title").regex(search),
				Criteria.where("content").regex(search)));

	this.filter(criteria, sort);

	Query query = new Query(criteria);
	query.with(new PageRequest(page - 1, size));

	this.sorting(query, sort);
	return mongoTemplate.find(query, Post.class);
}
 
開發者ID:forweaver,項目名稱:forweaver2.0,代碼行數:28,代碼來源:PostDao.java

示例3: updateUserChangeEmailField

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
/**
 * update v5: {@link UserDocument} has changed; String-Field 'email' was replaced with custom Type 'Email'.
 * find all user with an email String-value, replace String-Type with Custom-Type and update all UserDocuments.
 * if email-Field is Empty or null, you don't have to update user.
 *
 * @since V6
 */
@ChangeSet(order = "006", id = "updateUserChangeEmailFromStringToCustomClass", author = "admin")
public void updateUserChangeEmailField(final MongoTemplate template) {
  final Criteria isEmptyCriteria = new Criteria().orOperator(Criteria.where("email").is(""), Criteria.where("email").is(null));
  while (true) {
    final UserDocument result = template.findAndModify(new Query(isEmptyCriteria), Update.update("email", new Email()), UserDocument.class);
    if (result == null)
      break;
  }

  /**
   * if email not null -> Field will be cast to specific class and updates will create correct entries
   */
  // final Criteria isNotEmptyCriteria = new Criteria().orOperator(Criteria.where("email").ne(""), Criteria.where("email").ne(null));
  // final List<UserDocument> userDocumentList = template.find(new Query(isNotEmptyCriteria), UserDocument.class);

}
 
開發者ID:nkolytschew,項目名稱:mongobee_migration_example,代碼行數:24,代碼來源:DatabaseChangeLog.java

示例4: buildQuery

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
private Query buildQuery(AuthEventQueryRequest request) {
	Query query = new Query();

	if (!StringUtils.isEmpty(request.getRealm())) {
		query.addCriteria(Criteria.where("realm").is(request.getRealm()));
	}

	if (!StringUtils.isEmpty(request.getUsername())) {
		query.addCriteria(Criteria.where("username").regex(request.getUsername()));
	}

	if (request.getBeginDate() != null && request.getEndDate() != null) {
		query.addCriteria(new Criteria().andOperator(Criteria.where("loginAt").gte(request.getBeginDate()),
													 Criteria.where("loginAt").lte(request.getEndDate())));
	}
	else if (request.getBeginDate() != null) {
		query.addCriteria(Criteria.where("loginAt").gte(request.getBeginDate()));
	}
	else if (request.getEndDate() != null) {
		query.addCriteria(Criteria.where("loginAt").lte(request.getEndDate()));
	}

	Boolean succeed = request.getSucceed();
	if (succeed != null) {
		query.addCriteria(Criteria.where("succeed").is(succeed.booleanValue()));
	}

	return query;
}
 
開發者ID:melthaw,項目名稱:spring-backend-boilerplate,代碼行數:30,代碼來源:AuthEventRepositoryImpl.java

示例5: batchRemove

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
/**
 * 批量刪除補償事務信息
 *
 * @param ids             ids 事務id集合
 * @param applicationName 應用名稱
 * @return true 成功
 */
@Override
public Boolean batchRemove(List<String> ids, String applicationName) {
    if (CollectionUtils.isEmpty(ids) || StringUtils.isBlank(applicationName)) {
        return Boolean.FALSE;
    }
    final String mongoTableName = RepositoryPathUtils.buildMongoTableName(applicationName);

    ids.forEach(id -> {
        Query query = new Query();
        query.addCriteria(new Criteria("transId").is(id));
        mongoTemplate.remove(query, mongoTableName);
    });

    return Boolean.TRUE;
}
 
開發者ID:yu199195,項目名稱:happylifeplat-tcc,代碼行數:23,代碼來源:MongoCompensationServiceImpl.java

示例6: updateParticipant

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
/**
 * 更新 List<Participant>  隻更新這一個字段數據
 *
 * @param tccTransaction 實體對象
 */
@Override
public int updateParticipant(TccTransaction tccTransaction) {
    Query query = new Query();
    query.addCriteria(new Criteria("transId").is(tccTransaction.getTransId()));
    Update update = new Update();
    try {
        update.set("contents", objectSerializer.serialize(tccTransaction.getParticipants()));
    } catch (TccException e) {
        e.printStackTrace();
    }
    final WriteResult writeResult = template.updateFirst(query, update, MongoAdapter.class, collectionName);
    if (writeResult.getN() <= 0) {
        throw new TccRuntimeException("更新數據異常!");
    }
    return 1;
}
 
開發者ID:yu199195,項目名稱:happylifeplat-tcc,代碼行數:22,代碼來源:MongoCoordinatorRepository.java

示例7: updateNotebook

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
public void updateNotebook(Notebook notebook){
    Query query = new Query();
    query.addCriteria(new Criteria("NotebookId").is(notebook.getNotebookId()));
    Update update = new Update();
    update.set("title", notebook.getTitle());
    update.set("description", notebook.getDescription());
    update.set("creator", notebook.getCreator());
    update.set("owner", notebook.getOwner());
    update.set("star", notebook.getStar());
    update.set("collected", notebook.getCollected());
    update.set("clickCount", notebook.getClickCount());
    update.set("collaborators", notebook.getCollaborators());
    update.set("contributors", notebook.getContributors());
    update.set("notes", notebook.getNotes());
    update.set("createTime", notebook.getCreateTime());
    update.set("cover", notebook.getCover());
    update.set("tags", notebook.getTags());
    update.set("starers", notebook.getStarers());
    mongoTemplate.updateFirst(query, update, Notebook.class,"Notebook");
}
 
開發者ID:qinjr,項目名稱:TeamNote,代碼行數:21,代碼來源:NotebookDaoImpl.java

示例8: shouldRetrieveDataRelatedBooks

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
/**
 * Filter for Data-related books in their title and output the title and authors.
 */
@Test
public void shouldRetrieveDataRelatedBooks() {

	Aggregation aggregation = newAggregation( //
			match(Criteria.where("volumeInfo.title").regex("data", "i")), //
			replaceRoot("volumeInfo"), //
			project("title", "authors"), //
			sort(Direction.ASC, "title"));

	AggregationResults<BookAndAuthors> result = operations.aggregate(aggregation, "books", BookAndAuthors.class);

	BookAndAuthors bookAndAuthors = result.getMappedResults().get(1);

	assertThat(bookAndAuthors.getTitle()).isEqualTo("Spring Data");
	assertThat(bookAndAuthors.getAuthors()).contains("Mark Pollack", "Oliver Gierke", "Thomas Risberg", "Jon Brisbin",
			"Michael Hunger");
}
 
開發者ID:Just-Fun,項目名稱:spring-data-examples,代碼行數:21,代碼來源:SpringBooksIntegrationTests.java

示例9: getSprintStatsByKeywords

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
@Override
public SprintStats getSprintStatsByKeywords(List<String> boards) {

    Aggregation agg = newAggregation(
            match(Criteria
                    .where("keywords").in(boards)
                    .and("sSprintAssetState").is("CLOSED")
                    .and("sTypeName").in(Arrays.asList("Story","Bug"))
                    .and("sStatus").in(Arrays.asList("Accepted", "Done"))
            ),
            group("sSprintName")
                    .first("sprintBeginDate").as("start")
                    .first("sprintEndDate").as("end")
                    .sum("dEstimate").as("estimate")
            ,
            group()
                    .avg("estimate").as("estimateAvg")
                    .avg(
                            Ceil.ceilValueOf(
                                Divide.valueOf(
                                        Subtract.valueOf("end").subtract("start")
                                ).divideBy(3600 * 1000 * 24)
                        )
                    ).as("daysDurationAvg"),
            project("daysDurationAvg","estimateAvg")
                    .andExclude("_id")
    );

    AggregationResults<SprintStats> groupResults
            = mongoTemplate.aggregate(agg, "feature", SprintStats.class);
    return groupResults.getUniqueMappedResult();

}
 
開發者ID:BBVA,項目名稱:mirrorgate,代碼行數:34,代碼來源:FeatureRepositoryImpl.java

示例10: postUserSignin

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
@PostMapping("/signin")
public Mono<MyUser> postUserSignin(@RequestBody MyUser myUser)
		throws NoSuchAlgorithmException, InvalidKeySpecException {
	Query query = new Query();
	query.addCriteria(Criteria.where("userId").is(myUser.getUserId()));
	MyUser user = this.operations.findOne(query, MyUser.class).switchIfEmpty(Mono.just(new MyUser())).block();
	if (user.getUserId() == null) {
		String salt = this.passwordEncryption.generateSalt();
		String encryptedPassword = this.passwordEncryption.getEncryptedPassword(myUser.getPassword(), salt);
		myUser.setPassword(encryptedPassword);
		myUser.setSalt(salt);
		this.operations.save(myUser).block();
		return Mono.just(myUser);
	}
	return Mono.just(new MyUser());
}
 
開發者ID:Angular2Guy,項目名稱:AngularAndSpring,代碼行數:17,代碼來源:MyUserController.java

示例11: getTicket

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
@Override
public Ticket getTicket(final String ticketId) {
    try {
        LOGGER.debug("Locating ticket ticketId [{}]", ticketId);
        final String encTicketId = encodeTicketId(ticketId);
        if (encTicketId == null) {
            LOGGER.debug("Ticket ticketId [{}] could not be found", ticketId);
            return null;
        }
        final TicketHolder d = this.mongoTemplate.findOne(new Query(Criteria.where(TicketHolder.FIELD_NAME_ID).is(encTicketId)),
                TicketHolder.class, this.collectionName);
        if (d != null) {
            return deserializeTicketFromMongoDocument(d);
        }
    } catch (final Exception e) {
        LOGGER.error("Failed fetching [{}]: [{}]", ticketId, e);
    }
    return null;
}
 
開發者ID:mrluo735,項目名稱:cas-5.1.0,代碼行數:20,代碼來源:MongoDbTicketRegistry.java

示例12: getNextSequenceId

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的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

示例13: processPagePart

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
public static PageRequest processPagePart(Query query, PageQueryRequest queryRequest, Sort sort) {
	if (queryRequest instanceof DateRangedQueryRequest) {
		DateRangedQueryRequest dateRangedQueryRequest = (DateRangedQueryRequest) queryRequest;
		if (dateRangedQueryRequest.getBeginDate() != null && dateRangedQueryRequest.getEndDate() != null) {
			query.addCriteria(new Criteria().andOperator(Criteria.where("createdAt")
																 .gte(dateRangedQueryRequest.getBeginDate()),
														 Criteria.where("createdAt")
																 .lte(dateRangedQueryRequest.getEndDate())));
		}
		else if (dateRangedQueryRequest.getBeginDate() != null) {
			query.addCriteria(Criteria.where("createdAt").gte(dateRangedQueryRequest.getBeginDate()));
		}
		else if (dateRangedQueryRequest.getEndDate() != null) {
			query.addCriteria(Criteria.where("createdAt").lte(dateRangedQueryRequest.getEndDate()));
		}
	}

	int start = queryRequest.getStart();
	int limit = queryRequest.getLimit();

	PageRequest pageable = new PageRequest(start, limit, sort);
	query.with(pageable);

	return pageable;
}
 
開發者ID:melthaw,項目名稱:spring-backend-boilerplate,代碼行數:26,代碼來源:RepositoryCustomHelper.java

示例14: findById

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
/**
 * 根據id獲取對象
 *
 * @param id 主鍵id
 * @return TransactionRecover
 */
@Override
public TransactionRecover findById(String id) {
    Query query = new Query();
    query.addCriteria(new Criteria("transId").is(id));
    MongoAdapter cache = template.findOne(query, MongoAdapter.class, collectionName);
    return buildByCache(cache);

}
 
開發者ID:yu199195,項目名稱:happylifeplat-transaction,代碼行數:15,代碼來源:MongoTransactionRecoverRepository.java

示例15: findById

import org.springframework.data.mongodb.core.query.Criteria; //導入依賴的package包/類
/**
 * 根據id獲取對象
 *
 * @param id 主鍵id
 * @return TccTransaction
 */
@Override
public TccTransaction findById(String id) {
    Query query = new Query();
    query.addCriteria(new Criteria("transId").is(id));
    MongoAdapter cache = template.findOne(query, MongoAdapter.class, collectionName);
    return buildByCache(cache);

}
 
開發者ID:yu199195,項目名稱:happylifeplat-tcc,代碼行數:15,代碼來源:MongoCoordinatorRepository.java


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