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

网友投稿 344 2022-10-03


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

整合

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

org.mybatis.spring.boot

mybatis-spring-boot-starter

1.3.2

org.springframework.boot

spring-boot-starter-data-mongodb

org.mongodb

mongo-java-driver

3.12.7

com.alibaba

druid

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 启动类

* AeUEXil@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(MJSagentApplicatiAeUEXilon.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 findAll(){

return mongoTemplate.findAll(Student.class);

}

根据条件查询

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

实现:

/**

* 根据学生名称查询学生列表

* @param name

* @return

*/

public List findByName(String name){

//添加约束

Query query=new Query(Criteria.where("name").is(name));

//返回结果

return mongoTemplate.find(query,Student.class);

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:渗透测试与漏洞扫描有什么区别?(渗透测试主要是扫描)
下一篇:DNS:加强最薄弱环节(不能增强dns安全的是)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~