java中的接口是类吗
344
2022-10-03
springboot整合mongodb并实现crud步骤详解
整合
首先我们得使用springboot整合咱们的mongodb,第一步,当然是引入依赖啦
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
return mongoTemplate.findAll(Student.class);
}
根据条件查询
目标:根据学生名称查询学生列表
实现:
/**
* 根据学生名称查询学生列表
* @param name
* @return
*/
public List
//添加约束
Query query=new Query(Criteria.where("name").is(name));
//返回结果
return mongoTemplate.find(query,Student.class);
}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~