文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

springboot整合mongodb并实现crud步骤详解

2024-04-02 19:55

关注

整合

首先我们得使用springboot整合咱们的mongodb,第一步,当然是引入依赖啦


<!--mybatis-->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.2</version>
</dependency>
<!--mongodb-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.mongodb/mongo-java-driver -->
<dependency>
    <groupId>org.mongodb</groupId>
    <artifactId>mongo-java-driver</artifactId>
    <version>3.12.7</version>
</dependency>
<!--druid数据源-->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
</dependency>

applicaton.yml配置


spring:
  data:
    mongodb:
      #uri:  mongodb://localhost:27017/test
      host: 127.0.0.1
      port: 27017
      username:
      password:
      database: test
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource #druid数据源
mybatis:
  type-aliases-package: com.mjs.common.pojo  #这里是实体类所在的包
  mapper-locations: classpath:/mapper
@SpringBootApplication(exclude= {DataSourceAutoConfiguration.class})
@MapperScan(basePackages = "com.mjs.dao")
public class MJSagentApplication {
    public static void main(String[] args) {
        SpringApplication.run(MJSagentApplication.class,args);
    }
}

crud

到这里咱们就已经整合完成了,接下来,创建一个类 StudentDao,用于测试

然后再StudentDao中引入MongoTemplate,它底层帮我们封装好了对mondodb操作的代码,简化了我们开发时的操作,这样开发的时候我们有更多的时间去实现业务


@Autowired
private MongoTemplate mongoTemplate;

添加

写一个方法,添加一个学生,调用mongoTemplate中的save方法



public boolean insert(Student student){
    Student stu = mongoTemplate.save(student);
    return stu!=null;
}

当然在这里可以使用mongoTemplate自带的insert方法,两者效果相同

删除

咱们也用一个案例来理解删除

目标:根据名字删除学生

实现:



public boolean deleteByName(String name){
    //添加约束
    Query query =new Query(Criteria.where("name").is(name));
    //根据条件删除学生,并返回结果
    DeleteResult result = mongoTemplate.remove(query, Student.class);
    return result.getDeletedCount()>0;
}

其他条件可以根据该案例,举一反三

修改

目标:根据id修改学生信息

实现:



public boolean updateStu(Student student){
    //添加约束
    Query query =new Query(Criteria.where("id").is(student.getId()));
    //设置要修改的值
    Update update=new Update();
    update.set("age",student.getAge());
    update.set("sex",student.getAge());
    //修改并返回结果
    UpdateResult updateResult = mongoTemplate.updateFirst(query, update, Student.class);
    return updateResult.getMatchedCount()>0;
}

查询

无参数的查询所有



public List<Student> findAll(){
    return mongoTemplate.findAll(Student.class);
}

根据条件查询

目标:根据学生名称查询学生列表

实现:



public List<Student> findByName(String name){
    //添加约束
    Query query=new Query(Criteria.where("name").is(name));
    //返回结果
    return mongoTemplate.find(query,Student.class);
}

到此这篇关于springboot整合mongodb并实现crud的文章就介绍到这了,更多相关springboot整合mongodb内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯