使用MongoTemplate进行Spring启动

时间:2016-07-10 03:18:41

标签: java mongodb spring-boot mongotemplate mongorepository

我是Spring Boot和MongoDb的新手。 尝试使用Mongo Repositories和Spring Boot的一些示例。 但经过一些文件发现,Mongo Template将是一个更好的选择。无法使用Mongo Template示例获得正确的Spring Boot。

  1. 有人可以帮我一个例子。

  2. 在尝试使用Mongo模板时,是否需要创建用户定义的存储库界面并扩展存储库或CRUD存储库?

2 个答案:

答案 0 :(得分:3)

我找到了一些使用Mongo Template

的例子

http://docs.spring.io/spring-data/data-document/docs/current/reference/html/#mongo-template

http://www.mkyong.com/mongodb/spring-data-mongodb-hello-world-example/

如果您有兴趣使用JPA,请参阅下面的

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
<dependency>
    <groupId>org.mongodb</groupId>
    <artifactId>mongo-java-driver</artifactId>
    <version>{mongo.driver.version}</version>
</dependency>

application.properties

#Mongo DB
spring.data.mongodb.database=
spring.data.mongodb.host=
spring.data.mongodb.password=
spring.data.mongodb.port=
spring.data.mongodb.repositories.enabled=
spring.data.mongodb.uri=
spring.data.mongodb.username=

SpringBoot类

@SpringBootApplication
@EnableAutoConfiguration(exclude = { DataSourceAutoConfiguration.class, HibernateJpaAutoConfiguration.class })
public class UserApp {

Mongo存储库

@Repository
public interface UserRepository extends MongoRepository<User, Long> {}

答案 1 :(得分:0)

为进一步说明,您甚至可以同时使用两者。

MongoRepository只是一个抽象层,类似于MongoTemplate,但界面更简单。

如果您发现使用Spring query-creation进行某种操作太复杂了,并且又不希望使用@Query(例如,在构造查询时需要IDE类型提示),那么您可以可以扩展MongoRepository并将MongoTemplate用作查询机制。

首先,我们使用自定义界面扩展存储库。

@Repository
public interface ArticleRepository extends MongoRepository<Article, String>, CustomArticleRepository {
}

然后声明接口。

public interface CustomArticleRepository {
    List<Article> getArticleFilteredByPage(int page, int num);
}

然后实现我们的自定义存储库。我们可以在此处自动连接MongoTemplate并使用它来查询数据库。

public class CustomArticleRepositoryImpl implements CustomArticleRepository {

    @Autowired
    MongoTemplate mongoTemplate;

    @Override
    public List<Article> getArticleFilteredByPage(int page, int num) {
        return mongoTemplate.findAll(Article.class)
                .skip(page * num)
                .take(num);
    }
}

最后,我们使用ArticleRepository

@Service
public class ArticleServiceImpl {

    @Autowired
    private ArticleRepository articleRepository;

    public List<Article> getArticleByPage() {
        return articleRepository.getArticleFilteredByPage(1, 10);
    }
}