Springboot连接NoSQL数据库MongoDB,读取集合数据文档
Posted zhangphil
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Springboot连接NoSQL数据库MongoDB,读取集合数据文档相关的知识,希望对你有一定的参考价值。
这里有MongoDB搭建配置和启动介绍:
下面是在spring boot里面载入MongoDB,然后读取MongoDB的集合数据(基于上面文章创建的MongoDB数据库和集合)。
前提是启动MongoDB数据库:
mongod --dbpath=d:/mongodb/data
(1)写一个类,此类对应MongoDB里面集合的文档:
import org.springframework.data.mongodb.core.mapping.Document;
import org.springframework.data.mongodb.core.mapping.FieldType;
import org.springframework.data.mongodb.core.mapping.MongoId;
import java.util.List;
@Document
public class Person
@MongoId(value = FieldType.OBJECT_ID)
private String id;
private String name;
private String city;
private String age;
private List it;
public Person()
public Person(String id, String name, String city, String age, List it)
this.id = id;
this.name = name;
this.city = city;
this.age = age;
this.it = it;
public String getId()
return id;
public void setId(String id)
this.id = id;
public String getName()
return name;
public void setName(String name)
this.name = name;
public String getCity()
return city;
public void setCity(String city)
this.city = city;
public String getAge()
return age;
public void setAge(String age)
this.age = age;
public List getIt()
return it;
public void setIt(List it)
this.it = it;
@Override
public String toString()
return "" +
"id='" + id + '\\'' +
", name='" + name + '\\'' +
", city='" + city + '\\'' +
", age='" + age + '\\'' +
", it=" + it +
'';
(2)定义Person的存储访问接口:
import org.springframework.data.mongodb.repository.MongoRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface PersonRepository extends MongoRepository<Person, String>
完成PersonRepository的实现:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Example;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.repository.query.FluentQuery;
import org.springframework.stereotype.Component;
import java.util.List;
import java.util.Optional;
import java.util.function.Function;
@Component
public class PersonRepositoryImpl implements PersonRepository
@Autowired
private MongoTemplate mongoTemplate;
private final String COLLECTION_NAME = "zhangphil_collection";
@Override
public Optional<Person> findById(String id)
Person person = mongoTemplate.findById(id, Person.class, COLLECTION_NAME);
return Optional.of(person);
@Override
public List<Person> findAll()
return mongoTemplate.findAll(Person.class, COLLECTION_NAME);
@Override
public <S extends Person> List<S> saveAll(Iterable<S> entities)
return null;
@Override
public List<Person> findAll(Sort sort)
return null;
@Override
public <S extends Person> S insert(S entity)
return null;
@Override
public <S extends Person> List<S> insert(Iterable<S> entities)
return null;
@Override
public <S extends Person> List<S> findAll(Example<S> example)
return null;
@Override
public <S extends Person> List<S> findAll(Example<S> example, Sort sort)
return null;
@Override
public Page<Person> findAll(Pageable pageable)
return null;
@Override
public <S extends Person> S save(S entity)
return null;
@Override
public boolean existsById(String s)
return false;
@Override
public Iterable<Person> findAllById(Iterable<String> strings)
return null;
@Override
public long count()
return 0;
@Override
public void deleteById(String s)
@Override
public void delete(Person entity)
@Override
public void deleteAllById(Iterable<? extends String> strings)
@Override
public void deleteAll(Iterable<? extends Person> entities)
@Override
public void deleteAll()
@Override
public <S extends Person> Optional<S> findOne(Example<S> example)
return Optional.empty();
@Override
public <S extends Person> Page<S> findAll(Example<S> example, Pageable pageable)
return null;
@Override
public <S extends Person> long count(Example<S> example)
return 0;
@Override
public <S extends Person> boolean exists(Example<S> example)
return false;
@Override
public <S extends Person, R> R findBy(Example<S> example, Function<FluentQuery.FetchableFluentQuery<S>, R> queryFunction)
return null;
重点是前两个函数,findAll和findById。后面的函数本项目中暂不使用。
(3)写一个控制器:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
import java.util.Optional;
@RestController
@RequestMapping("/person") //父域
public class PersonController
@Autowired
private PersonRepositoryImpl personRepository;
public PersonController(PersonRepositoryImpl personRepository)
this.personRepository = personRepository;
@GetMapping("")
public String getAllPerson()
List<Person> persons = personRepository.findAll();
String str = "";
for (Person p : persons)
str = str + p + "\\n";
return str;
@GetMapping("/personId")
public String findByPersonId(@PathVariable String personId)
Optional<Person> optional = personRepository.findById(personId);
return optional.get().toString();
(4)在application.properties里面定义MongoDB的访问配置:
spring.data.mongodb.host=localhost
spring.data.mongodb.port=27017
spring.data.mongodb.database=zhangphil_db
写好后,运行,在浏览器访问 http://localhost:8080/person
返回结果:
id='61dea31fe74004760a936564', name='zhangphil', city='Chengdu', age='2021', it=[spring, mongo, mysql, python, android, java]
在浏览器访问
http://localhost:8080/person/61dea31fe74004760a936564
返回:
id='61dea31fe74004760a936564', name='zhangphil', city='Chengdu', age='2021', it=[spring, mongo, mysql, python, android, java]
以上是关于Springboot连接NoSQL数据库MongoDB,读取集合数据文档的主要内容,如果未能解决你的问题,请参考以下文章
Springboot连接NoSQL数据库MongoDB,读取集合数据文档
Springboot连接NoSQL数据库MongoDB,读取集合数据文档
NoSQL概述-从Mongo和Cassandra谈谈NoSQL