依赖:

        <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-mongodb -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

配置

application.properties:

#spring.data.mongodb.uri=mongodb://localhost:27017/sea
spring.data.mongodb.uri=mongodb://用户名:密码@localhost:27017/sea 或者:

#spring.data.mongodb.uri=mongodb://userName:password@ip:port/database
spring.data.mongodb.database=ELSA_MILESTONE_SUBSCRIPTION_SERVICE
spring.data.mongodb.host=localhost
spring.data.mongodb.port=27017
#spring.data.mongodb.username=mongodb
#spring.data.mongodb.password=root


方式:1: 使用

@Autowired
private MongoTemplate mongoTemplate;

eg:

package com.icil.dao;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;
import org.springframework.stereotype.Repository; import com.icil.domain.UserEntity;
@Repository
public class UserDAO { @Autowired
private MongoTemplate mongoTemplate; /**
* 创建对象
* @param user
*/
public void saveUser(UserEntity user) {
mongoTemplate.save(user);
} /**
* 根据用户名查询对象
* @param userName
* @return
*/
public UserEntity findUserByUserName(String userName) {
Query query=new Query(Criteria.where("userName").is(userName));
UserEntity user = mongoTemplate.findOne(query , UserEntity.class);
return user;
} /**
* 更新对象
* @param user
*/
public void updateUser(UserEntity user) {
Query query=new Query(Criteria.where("id").is(user.getId()));
Update update= new Update().set("userName", user.getUserName()).set("passWord", user.getPassWord());
//更新查询返回结果集的第一条
mongoTemplate.updateFirst(query,update,UserEntity.class);
//更新查询返回结果集的所有
// mongoTemplate.updateMulti(query,update,UserEntity.class);
} /**
* 删除对象
* @param id
*/
public void deleteUserById(Long id) {
Query query=new Query(Criteria.where("id").is(id));
mongoTemplate.remove(query,UserEntity.class);
} }

高频使用: 多条件 动态 (类似mybtis)

     @Autowired
private MongoTemplate mongoTemplate;
@Test
public void testNameQuery() throws Exception {
//collectionName -->
Criteria criteria1 = Criteria.where("collName").is("lzd_work_table_collection");
Criteria criteria2 = Criteria.where("status").is("RCS"); Query query = new Query();
query.addCriteria(criteria1);
query.addCriteria(criteria2);
System.err.println(query);
// Query query=new Query(Criteria.where("status").is("RSC"));
// public <T> List<T> find(Query query, Class<T> entityClass, String collectionName) {
List<MilestoneInfo> find = mongoTemplate.find(query,MilestoneInfo.class);
System.err.println("#######################");
System.err.println(find);
}

方式2:extends MongoRepository

eg:

UserRepository.java

package com.sea.test.repository;

import java.util.List;

import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.data.mongodb.repository.MongoRepository;
import org.springframework.data.mongodb.repository.Query; import com.sea.test.pojo.User; public interface UserRepository extends MongoRepository<User, Long> { /**
* Like(模糊查询)
* {"username" : name} ( name as regex)
* */
List<User> findByUsernameLike(String username); List<User> findByUsernameLike(String username,PageRequest pageable); /**
* Like(模糊查询)
* {"username" : name}
* */
List<User> findByUsername(String username); /**
* GreaterThan(大于)
* {"age" : {"$gt" : age}}
* */
List<User> findByAgeGreaterThan(int age);
/**
* LessThan(小于)
* {"age" : {"$lt" : age}}
* */
List<User> findByAgeLessThan(int age);
/**
* Between(在...之间)
* {{"age" : {"$gt" : from, "$lt" : to}}
* */
List<User> findByAgeBetween(int from, int to); /**
* IsNotNull, NotNull(是否非空)
* {"username" : {"$ne" : null}}
* */
List<User> findByUsernameNotNull(); /**
* IsNull, Null(是否为空)
* {"username" : null}
* */
List<User> findByUsernameNull(); /**
* Not(不包含)
* {"username" : {"$ne" : name}}
* */
List<User> findByUsernameNot(String name); /**
* Near(查询地理位置相近的)
* {"location" : {"$near" : [x,y]}}
* */
// findByLocationNear(Point point) /**
* Within(在地理位置范围内的)
* {"location" : {"$within" : {"$center" : [ [x, y], distance]}}}
* */
//findByLocationWithin(Circle circle) /**
* Within(在地理位置范围内的)
* {"location" : {"$within" : {"$box" : [ [x1, y1], x2, y2]}}}
* */
// findByLocationWithin(Box box) /**
*
* @param name
* @param age
* @param page
* @return
*/
@Query("{\"username\":{\"$regex\":?0}, \"age\": ?1}")
Page<User> findByNameAndAgeRange(String name,int age,Pageable page); /**
*
* @param name
* @param ageFrom
* @param ageTo
* @param page
* @return
*/
@Query(value="{\"username\":{\"$regex\":?0},\"age\":{\"$gte\":?1,\"$lte\": ?2}}")
Page<User> findByNameAndAgeRange2(String name,int ageFrom,int ageTo,Pageable page); @Query(value="{\"username\":{\"$regex\":?0},\"age\":{\"$gte\":?1,\"$lte\": ?2}}",fields="{\"username\" : 1, \"age\" : 1}")
Page<User> findByNameAndAgeRange3(String name,int ageFrom,int ageTo,Pageable page); }

User:

package com.sea.test.pojo;

import java.io.Serializable;

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;
import org.springframework.data.mongodb.core.mapping.Field;
import org.springframework.stereotype.Component; import com.sea.test.annotation.AutoIncKey;
import com.sea.test.annotation.aop.SeaAnnotion; import lombok.Getter;
import lombok.Setter;
import lombok.ToString; @Getter
@Setter
@ToString
@Component
@Document(collection = "My_user") //指定别名
public class User implements Serializable { private static final long serialVersionUID = -1L; @Id //指定id
@AutoIncKey //自定义注解
private Long id; @Field("userName") //指定匹配关系
private String username; private Integer age; @SeaAnnotion()
public Long getId() {
return id;
} @SeaAnnotion()
public void setId(Long id) {
this.id = id;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
} public User() {
super();
} public User(Long id, String username) {
super();
this.id = id;
this.username = username;
} public User(Long id, String username, Integer age) {
super();
this.id = id;
this.username = username;
this.age = age;
} @Override
public String toString() {
return "User [id=" + id + ", username=" + username + ", age=" + age + "]";
} }

controller : 参考https://blog.csdn.net/weixin_39214304/article/details/84791953

package com.sea.test.controller;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Example;
import org.springframework.data.domain.ExampleMatcher;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Sort;
import org.springframework.data.domain.Sort.Direction;
import org.springframework.data.domain.Sort.Order;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseStatus;
import org.springframework.web.bind.annotation.RestController; import com.sea.test.pojo.User;
import com.sea.test.repository.UserRepository; @RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserRepository userRepository; @ResponseStatus(HttpStatus.CREATED)
@PostMapping(consumes = MediaType.APPLICATION_JSON_VALUE)
public User createUser(@RequestBody User user) {
return userRepository.save(user);
} /**
* 根据id查询
*
* @param id
* @return
*/
@GetMapping(value = "/{id}")
public User readUserById(@PathVariable("id") Long id) {
return userRepository.findById(id).get();
} @GetMapping(value = "/all")
public List<User> getAll() {
System.err.println("### enter into getall emthod ###");
return userRepository.findAll();
} /**
* 根据一个或者多个属性查询单个结果
*
* @param name
* @return
*/
@GetMapping(value = "/name/{name}")
public User readUserByName(@PathVariable("name") String name) {
User user = new User();
user.setUsername(name);
ExampleMatcher matcher = ExampleMatcher.matching().withIgnorePaths("age", "createTime");
Example<User> example = Example.of(user, matcher);
return userRepository.findOne(example).get();
} /**
* 根据一个或者多个属性分页查询
*
* @param pageNumber
* @param pageSize
* @return
*/
@GetMapping(value = "/page/{pageNumber}/pagesize/{pageSize}/name/{name}")
public Page<User> readUsersByPage(@PathVariable("pageNumber") int pageNumber,
@PathVariable("pageSize") int pageSize, @PathVariable("name") String name) {
User user = new User();
user.setUsername(name);
ExampleMatcher matcher = ExampleMatcher.matching().withIgnorePaths("age", "createTime");
Example<User> example = Example.of(user, matcher);
if (pageNumber < ) {
pageNumber = ;
} else if (pageSize == ) {
pageSize = ;
}
PageRequest pageable = PageRequest.of(pageNumber - , pageSize);
return userRepository.findAll(example, pageable);
} /**
* 根据用户年龄升序排序
*
* @return
*/
@GetMapping("/get")
public List<User> readUsers() {
System.err.println("### enter into readUser emthod ###");
Order order = new Order(Direction.ASC, "age");
Sort sort = Sort.by(order);
return userRepository.findAll(sort);
} /**
* 模糊查询带分页
*
* @param pageNumber
* @param pageSize
* @param keyWords
* @return
*/
@GetMapping(value = "/page/{pageNumber}/pagesize/{pageSize}/keyword/{keyWords}")
public Page<User> readUsersByKeywords(@PathVariable("pageNumber") int pageNumber,
@PathVariable("pageSize") int pageSize, @PathVariable("keyWords") String keyWords) {
if (keyWords == null) {
keyWords = "";
}
if (pageNumber < ) {
pageNumber = ;
} else if (pageSize == ) {
pageSize = ;
}
PageRequest pageable = PageRequest.of(pageNumber - , pageSize);
return (Page<User>) userRepository.findByUsernameLike(keyWords, pageable);
} @ResponseStatus(HttpStatus.OK)
@DeleteMapping(value = "/{id}")
public void removeUser(@PathVariable("id") Long id) {
userRepository.deleteById(id);
}
}

springBoot整合MongoDB(单机)的更多相关文章

  1. java操作mongodb & springboot整合mongodb

    简单的研究原生API操作MongoDB以及封装的工具类操作,最后也会研究整合spring之后作为dao层的完整的操作. 1.原生的API操作 pom.xml <!-- https://mvnre ...

  2. SpringBoot整合mongoDB

    MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的. 这一片文章介绍一个springboot整合mongodb,如果你了解整合mysql之类的 ...

  3. SpringBoot 整合mongoDB并自定义连接池

    SpringBoot 整合mongoDB并自定义连接池 得力于SpringBoot的特性,整合mongoDB是很容易的,我们整合mongoDB的目的就是想用它给我们提供的mongoTemplate,它 ...

  4. Springboot整合MongoDB的Docker开发,其它应用也类似

    1 前言 Docker是容器开发的事实标准,而Springboot是Java微服务常用框架,二者必然是会走到一起的.本文将讲解如何开发Springboot项目,把它做成Docker镜像,并运行起来. ...

  5. 8、SpringBoot整合之SpringBoot整合MongoDB

    SpringBoot整合MongoDB 一.创建项目,选择依赖 仅选择Spring Web.Spring Data MongoDB即可 二.引入相关依赖(非必要) 这里只是为了实体类的创建方便而引入l ...

  6. Springboot 整合 MongoDB

    Springboot 整合 MongoDB 这节我们将整合 Spring Boot 与 Mongo DB 实现增删改查的功能,并且实现序列递增. Mongo DB 的基本介绍和增删改查的用法可以参考我 ...

  7. SpringBoot 整合 MongoDB 实战介绍

    一.介绍 在前面的文章中,我们详细的介绍了 MongoDB 的配置和使用,如果你对 MongoDB 还不是很了解,也没关系,在 MongoDB 中有三个比较重要的名词:数据库.集合.文档! 数据库(D ...

  8. SpringBoot非官方教程 | 第八篇:springboot整合mongodb

    转载请标明出处: 原文首发于:https://www.fangzhipeng.com/springboot/2017/07/11/springboot8-mongodb/ 本文出自方志朋的博客 这篇文 ...

  9. 实例讲解Springboot整合MongoDB进行CRUD操作的两种方式

    1 简介 Springboot是最简单的使用Spring的方式,而MongoDB是最流行的NoSQL数据库.两者在分布式.微服务架构中使用率极高,本文将用实例介绍如何在Springboot中整合Mon ...

  10. Springboot整合MongoDB(Eclipse版本)

    IDEA版本其实也差不多的,大同小异 简单Demo地址: https://blog.csdn.net/shirukai/article/details/82152243 Springboot项目整合M ...

随机推荐

  1. 峰Redis学习(7)Redis 持久化RDB方式

    第一节:Redis 持久化介绍 redis所有的数据都存在内存中,所以速度非常快,但是一旦断电等情况,数据就没了.从内存当中同步到硬盘上,这个过程叫做持久化过程. 持久化操作,两种方式:rdb方式.a ...

  2. Nodejs使用多个分隔符分隔字符串

    在nodejs中当需要使用多个分隔符分隔字符串时,可以使用正则表达式作为split函数的参数,具体使用如下: var str = "111@222#333 444@555# 666 777& ...

  3. 学习笔记之Python全栈开发/人工智能公开课_腾讯课堂

    Python全栈开发/人工智能公开课_腾讯课堂 https://ke.qq.com/course/190378 https://github.com/haoran119/ke.qq.com.pytho ...

  4. C语言强化——数组

    打印九九乘法表 #include<stdio.h> int main() { int num = 1; for (int i = 1;i <= 9;++i) { for (int j ...

  5. python直接下载图片到内存

    1. 使用requests(推荐) from PIL import Image import requests Image.open(requests.get(url, stream=True).ra ...

  6. 函数的进阶(动态参数,命名空间和作用域,函数的嵌套,gloabal和nonlocal关键字)

    1. 函数参数--动态传参 昨天已经解过了传参, 如果需要给一个函数传参,而参数又是不确定的. 或者我们给一个函数传很多参数, 我的形参就要写很多, 写起来就很麻烦, 这时我们可以考虑使用动态参数.形 ...

  7. adb显示 部分乱码修改方法

    用windows自带的命令行[cmd]软件链接adb 设备后,部分显示乱码,如下图片所示: 图1 修改方法如下: alias ls='busybox ls --color=never' 修改后显示正常 ...

  8. sas 解析json

    代码: proc ds2;data _null_;    method init();        dcl package json j();        dcl int rc tokenType ...

  9. python类型强转&二级容器

    Number 类型强转 int :         ---->>>   float,  bool,  complex,  str Float :        ---->> ...

  10. C# DataGirdview手动添加数据,导出txt文件并自动对齐

    //DataGirdview手动添加数据 private void btnDataGirdView_Click(object sender,EventArgs e) {       dataGridV ...