springboot集成MongoDB并在代码中实现增删改查相关语法

在项目中使用MongoDB文档数据库很频繁,存储一些非结构化数据、第三方回调数据、日志、以及一些不是那么实时需要的数据等等,当然document也可以是结构化的数据;

在职场中会有一些新入职的同事或者同为程序员的小伙伴初用MongoDB不太了解如何入手,下面就介绍一下springboot集成MongoDB并进行增删改查相关操作

1、在springboot中引入MongoDB依赖

bash 复制代码
		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
            <version>2.3.4.RELEASE</version>
        </dependency>

2、配置文件配置mongo数据库连接

bash 复制代码
spring.data.mongodb.uri=mongodb://root:123456@localhost:27017/test

root:数据库账号

123456:数据库密码 搭建数据库密码尽量复杂

localhost:数据库ip,可替换具体部署服务器公网ip

27017:数据库开放端口,可映射为其它端口提高安全性

test:数据库名

3、创建Mongo实体类并映射具体集合

bash 复制代码
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.data.mongodb.core.mapping.Document;
import org.springframework.data.mongodb.core.mapping.Field;

import java.io.Serializable;

/**
 * @desc: 登录日志
 * @Author: nuoyi
 * @Date: 2023/11/13 10:47 下午
 */
@AllArgsConstructor
@NoArgsConstructor
@Data
@Builder
@Document("NuoYi_Login_Log")
public class LoginLogPo implements Serializable {
	/**
	* 主键id 自动映射到_id
	*/
	@MongoId
    private String id;
    /**
     * 用户名
     */
    @Field(value = "accountName")
    private String accountName;
    /**
     * 用户Id
     */
    @Field(value = "accountId")
    private Integer accountId;
    /**
     * 手机号
     */
    @Field(value = "mobile")
    private String mobile;

    /**
     * 登录时间
     */
    @Field(value = "loginTime")
    private String loginTime;

    /**
     * 状态码
     */
    @Field(value = "stateCode")
    private Integer stateCode;

    /**
     * 登录IP
     */
    @Field(value = "host")
    private String host;

}

4、对mongo集合进行增删改查

新增

bash 复制代码
            private final MongoTemplate mongoTemplate;


            // 构建日志对象  
            BehaviorLogPo behaviorLogPo = BehaviorLogPo.builder()
                    .requestIp(IPUtil.getIpAddr(getHttpServletRequest()))
                    .accountName(accountInfo.getName())
                    .mobile(accountInfo.getMobile())
                    .interfaceReturnResult(getResultJsonStr(result))
                    .apiDoc(apiDesc.apiMode() + " -> " + apiDesc.apiName())
                    .interfaceOperationType(apiDesc.operateType().name())
                    .requestType(httpServletRequest.getMethod())
                    .build();

            // 存到mongo里边去
            mongoTemplate.save(behaviorLogPo);

删除

bash 复制代码
			Query query1 = new Query();
            query1.addCriteria(Criteria.where("_id").is(1));
            mongoTemplate.findAndRemove(query1,BehaviorLogPo.class);

修改

bash 复制代码
						Query query1 = new Query();
                        query1.addCriteria(Criteria.where("_id").is(t.getId()));
                        Update update = new Update();
                        update.set("accountId", 1);
                        UpdateResult updateResult = mongoTemplate.updateFirst(query, update, 	BehaviorLogPo.class);

查询(分页、包含、等于、模糊、时间范围)

bash 复制代码
	    /**
	     * mongo 模糊查询正则表达式
	     */
    	private final String reg = "^.*%s.*$";

		Query query = new Query();
        // 构建分页对象
        Pageable pageable = PageRequest.of(0, 5000);
        query.addCriteria(Criteria.where("stateCode").in((Object) null));
        query.addCriteria(Criteria.where("host").is("127.0.0.1");
        query.addCriteria(Criteria.where("mobile").regex(Pattern.compile(String.format(reg, req.getUserPhone()), Pattern.CASE_INSENSITIVE)));
        String startTime = "2023-01-06 00:00:00";
        String endTime = "2023-12-06 23:59:59";

        query.addCriteria(Criteria.where("loginTime").gt(startTime).lt(endTime));
        query.with(pageable).with(Sort.by(Sort.Order.asc("loginTime")));

        List<BehaviorLogPo> dataWaitHandle = mongoTemplate.find(query, AICallInfoLog.class, "NuoYi_Login_Log");

简单的相关操作就掌握啦

springboot中使用Java代码进行MongoDB集合数据备份
docker搭建mongodb并挂载外部文件
docker内部署MongoDB授权数据库账号权限

相关推荐
爱敲代码的小鱼1 小时前
springboot(2)从基础到项目创建:
java·spring boot·spring
i220818 Faiz Ul2 小时前
动漫商城|基于springboot + vue动漫商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·动漫商城系统
ybwycx4 小时前
SpringBoot下获取resources目录下文件的常用方法
java·spring boot·后端
zdl6865 小时前
springboot+全局异常处理
java·spring boot·spring
Full Stack Developme6 小时前
SpringBoot多线程池配置
spring boot·后端·firefox
计算机毕业论文辅导6 小时前
毕业设计避坑指南:工资信息管理系统的设计与实现(Java+SpringBoot实战)
java·spring boot·课程设计
sxhcwgcy7 小时前
SpringBoot 使用 spring.profiles.active 来区分不同环境配置
spring boot·后端·spring
清风絮柳8 小时前
65.少儿英语微信小程序
vue.js·spring boot·微信小程序·小程序·毕业设计
Java成神之路-8 小时前
MyBatis 开发模式演进:原生、Spring 与 Spring Boot 整合实战(MyBatis系列2)
spring boot·spring·mybatis
Yiyi_Coding9 小时前
SpringBoot4.X: 彻底消灭 NullPointerException
spring boot