2014-01-10 76 views
0

我目前正在爲我的大學項目編寫一個webapp。這是一個允許創建,修改和進行語言測試的系統。我的老師對我的問題搜索模塊感興趣。對於DB我使用MongoDB。他問我如果有5kk記錄要在瀏覽器中查看?他建議我在MongoDB中進行一些聚合。Spring Data中的聚合錯誤MongoDB

我必須做一個搜索方法,它可以讓我從收集文件中搜索1到5個標準:類別,問題,難度,問題類型,正確答案的數量。當然,在瀏覽器中查看它。

起初,我嘗試了基本操作,如使用條件創建新的查詢,但我需要它在任何數量的標準上工作,而不是全部或一個。如果一個或多個字段爲空,則不應在搜索中考慮,因此我正在嘗試進行聚合,但我無法使其工作,並且不知道我想要實現的是甚至是甚至可能用這種方法。

而且這裏是我的問題。在DAO中,我嘗試定義一個聚合,但它不識別組以及該類的方法(方法未定義)。

這裏是我的代碼:

public List<Question> findQuestions(Question question) { 
    String questionPattern = question.getQuestion().length() == 0 ? ".*" : ".*" + question.getQuestion() + ".*"; 

    TypedAggregation<Question> agg = newAggregation(Question.class, group("category"), 
      match(where("category").is(question.getCategory())) 

     ); 

     AggregationResults<Question> result = mongoTemplate.aggregate(agg, Question.class); 
     List<Question> stateStatsList = result.getMappedResults(); 
} 

和pom.xml中:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> 
<modelVersion>4.0.0</modelVersion> 
<groupId>com.pgs.languageskillchecker</groupId> 
<artifactId>LanguageSkillChecker</artifactId> 
<packaging>war</packaging> 
<version>1.0-SNAPSHOT</version> 
<name>LanguageSkillChecker</name> 
<url>http://maven.apache.org</url> 

<properties> 
    <spring.version>3.1.2.RELEASE</spring.version> 
</properties> 

<dependencies> 

    <!-- Spring --> 

    <dependency> 
     <groupId>org.springframework</groupId> 
     <artifactId>spring-context</artifactId> 
     <version>3.2.3.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework.security</groupId> 
     <artifactId>spring-security-config</artifactId> 
     <version>3.1.2.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework.security</groupId> 
     <artifactId>spring-security-core</artifactId> 
     <version>3.1.2.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework.security</groupId> 
     <artifactId>spring-security-web</artifactId> 
     <version>3.1.2.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework</groupId> 
     <artifactId>spring-core</artifactId> 
     <version>3.2.3.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework</groupId> 
     <artifactId>spring-aspects</artifactId> 
     <version>3.1.2.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework</groupId> 
     <artifactId>spring-web</artifactId> 
     <version>3.2.3.RELEASE</version> 
    </dependency> 

    <dependency> 
     <groupId>org.springframework</groupId> 
     <artifactId>spring-webmvc</artifactId> 
     <version>3.2.3.RELEASE</version> 
    </dependency> 

    <!-- Velocity --> 

    <dependency> 
     <groupId>org.apache.velocity</groupId> 
     <artifactId>velocity</artifactId> 
     <version>1.7</version> 
    </dependency> 

    <!-- Jackson --> 

    <dependency> 
     <groupId>org.codehaus.jackson</groupId> 
     <artifactId>jackson-mapper-asl</artifactId> 
     <version>1.9.12</version> 
    </dependency> 

    <!-- Servlet --> 

    <dependency> 
     <groupId>javax.servlet</groupId> 
     <artifactId>servlet-api</artifactId> 
     <version>2.5</version> 
    </dependency> 

    <!-- MongoDB -->  

    <dependency> 
     <groupId>org.springframework.data</groupId> 
     <artifactId>spring-data-mongodb</artifactId> 
     <version>1.3.3.RELEASE</version> 
    </dependency> 

    <!-- Sitemesh --> 

    <dependency> 
     <groupId>org.sitemesh</groupId> 
     <artifactId>sitemesh</artifactId> 
     <version>3.0-alpha-1</version> 
    </dependency> 

    <!-- AspectJ --> 

    <dependency> 
     <groupId>org.aspectj</groupId> 
     <artifactId>aspectjrt</artifactId> 
     <version>1.6.10</version> 
    </dependency> 

    <!-- poi --> 

    <dependency> 
     <groupId>org.apache.poi</groupId> 
     <artifactId>poi-ooxml</artifactId> 
     <version>3.9</version> 
    </dependency> 

    <!-- File upload --> 

    <dependency> 
     <groupId>commons-fileupload</groupId> 
     <artifactId>commons-fileupload</artifactId> 
     <version>1.3</version> 
    </dependency> 

</dependencies> 

<build> 
    <finalName>LanguageSkillChecker</finalName> 
    <plugins> 
     <plugin> 
      <groupId>org.apache.maven.plugins</groupId> 
      <artifactId>maven-compiler-plugin</artifactId> 
      <version>3.1</version> 
      <configuration> 
       <source>1.7</source> 
       <target>1.7</target> 
      </configuration> 
     </plugin> 
    </plugins> 
</build> 

我當然導入所需的庫:

import org.springframework.data.mongodb.core.aggregation.AggregationResults; 
import org.springframework.data.mongodb.core.aggregation.TypedAggregation; 
import org.springframework.data.mongodb.core.aggregation.Aggregation.*; 

我把聚集來自Spring IO Docs的代碼,但我無法讓它正常工作。我會感謝任何幫助^^

+0

你可以說你的實際問題是什麼開始。 – evanchooly

+0

我必須做一個搜索方法,它可以讓我從數據庫中搜索1到5個標準:類別,問題,難度,問題類型,正確答案的數量。 – Archer

+0

和你的失敗在你的嘗試以什麼方式? – evanchooly

回答

0

而且這裏是我的問題。在DAO中,我嘗試定義一個聚合,但它不識別組以及該類的方法(方法爲 未定義)。

這些方法(其中和組)是static,並在標準和聚合類中定義的 - 你只是缺少一個static進口。

import static org.springframework.data.mongodb.core.aggregation.Aggregation.*; 
import static org.springframework.data.mongodb.core.query.Criteria.*; 

或者更具體地說

import static org.springframework.data.mongodb.core.aggregation.Aggregation.group; 
import static org.springframework.data.mongodb.core.query.Criteria.where;