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授权数据库账号权限

相关推荐
Dolphin_Home1 小时前
笔记:SpringBoot静态类调用Bean的2种方案(小白友好版)
java·spring boot·笔记
刘一说2 小时前
Nacos 权限控制详解:从开源版 v2.2+ 到企业级安全实践
spring boot·安全·spring cloud·微服务·nacos·架构·开源
Q_Q5110082853 小时前
python+django/flask+vue的大健康养老公寓管理系统
spring boot·python·django·flask·node.js
czlczl200209253 小时前
通过哪些条件确定用哪个消息转换器
spring boot
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 个人健康管理系统为例,包含答辩的问题和答案
java·spring boot
qq_12498707534 小时前
基于微信小程序的线下点餐系统的设计与实现(源码+论文+部署+安装)
spring boot·微信小程序·小程序·毕业设计
IT_Octopus5 小时前
Java GZip 压缩实践 +实践思考 +进一步压榨性能和存储方案思考:Protobuf+ GZip
java·spring boot
毕设源码-郭学长5 小时前
【开题答辩全过程】以 高校教材大管家系统为例,包含答辩的问题和答案
java·spring boot
qq_12498707536 小时前
基于SpringBoot+vue的小黄蜂外卖平台(源码+论文+部署+安装)
java·开发语言·vue.js·spring boot·后端·mysql·毕业设计
i02086 小时前
Java 17 + Spring Boot 3.2.5 使用 Redis 实现“生产者–消费者”任务队列
java·spring boot·redis