springboot整合mongodb并实现crud步骤详解
整合
首先我们得使用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/*.xml #这里是放sql语句的映射文件
紧接着呢,就是咱们的启动类了(Application.class)需要添加注解让它去扫描咱们的dao层。
代码实现:
/** * @description 启动类 * @author shenwang * @version 1.0 * @date 2021/8/20 10:37 */ @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方法
/** * 添加学生 * @param student */ public boolean insert(Student student){ Student stu = mongoTemplate.save(student); return stu!=null; }
当然在这里可以使用mongoTemplate自带的insert方法,两者效果相同
删除
咱们也用一个案例来理解删除
目标:根据名字删除学生
实现:
/** * 根据学生姓名删除学生 * @param name * @return */ 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修改学生信息
实现:
/** * 根据ID修改学生信息 * @param student * @return */ 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; }
查询
无参数的查询所有
/** * 获取所有学生 * @return */ public List<Student> findAll(){ return mongoTemplate.findAll(Student.class); }
根据条件查询
目标:根据学生名称查询学生列表
实现:
/** * 根据学生名称查询学生列表 * @param name * @return */ 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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
PowerJob的AbstractScriptProcessor实现类工作流程源码解读
这篇文章主要为大家介绍了PowerJob的AbstractScriptProcessor源码流程解读,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2024-01-01Java中使用DOM4J生成xml文件并解析xml文件的操作
这篇文章主要介绍了Java中使用DOM4J来生成xml文件和解析xml文件的操作,今天通过代码给大家展示了解析xml文件和生成xml文件的方法,需要的朋友可以参考下2021-09-09Spring IOC中对象的创建、策略及销毁时机和生命周期详解
这篇文章主要介绍了Spring IOC中对象的创建、策略及销毁时机和生命周期详解,Spring默认使用类的空参构造方法创建bean,假如类没有空参构造方法,将无法完成bean的创建,需要的朋友可以参考下2023-08-08
最新评论