springBoot 使用MongoDB

springBoot 使用MongoDB 例子

项目地址(持续更新中):https://github.com/lizhongxiang12138/demo-mongo

test目录下有测试的列子

添加依赖

<dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

application.yml 配置

spring:
   data:
     mongodb:
       uri: mongodb://用户名:密码@地址:端口/数据库

添加dao接口

package com.lzx.mongo.demomongo.dao;

import com.lzx.mongo.demomongo.mogonentity.Student;
import org.springframework.data.mongodb.repository.MongoRepository;

import java.util.List;

public interface StudentDao extends MongoRepository<Student,String> {


    List<Student> findByNameContains(String name);

}

测试

测试类

package com.lzx.mongo.demomongo.dao;


import com.lzx.mongo.demomongo.mogonentity.Student;
import com.mongodb.client.result.UpdateResult;
import lombok.extern.slf4j.Slf4j;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.linuxprobe.luava.json.JacksonUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.List;
import java.util.Map;

@SpringBootTest
@RunWith(SpringRunner.class)
@Slf4j
public class StudentDaoTest {

    @Autowired
    StudentDao studentDao;

    @Autowired
    private MongoTemplate mongoTemplate;

    /**
     * 保存测试
     */
    @Test
    public void save(){
        Student student = new Student();
//        @Id
//        private String id;
        //没有设置id时是新增
        student.setId("60acc0b7df06d613edf45f33");
        student.setName("关羽");
        student.setAge("500");
        student.setCountry("汉");
        student.setJob("将军");
        //student.setCDate(new Date());
        Student save = studentDao.save(student);



        log.info(JacksonUtils.toJsonString(save));
    }

    /**
     * 查询测试
     */
    @Test
    public void findAll(){
        //根据id查询
        Student all = studentDao.findById("60acc0b7df06d613edf45f33").orElse(null);
        log.info(JacksonUtils.toJsonString(all));

        //dao 自定义方法查询
        List<Student> findByNameContains = studentDao.findByNameContains("张");
        log.info(JacksonUtils.toJsonString(findByNameContains));

        //动态定义条件查询
        Criteria c = new Criteria();
        c.and("id").is("60acc0b7df06d613edf45f");
        c.and("job").regex(".*将.*");
        Query query = new Query(c);
        List<Student> students = mongoTemplate.find(query, Student.class);
        log.info(JacksonUtils.toJsonString(students));
    }

    /**
     * 更新指定字段
     */
    @Test
    public void updateField(){
        Query query = new Query(Criteria.where("id").is("60acc0b7df06d613edf45f33"));
        Update update = new Update();
        update.set("job","蜀国将军");
        UpdateResult updateResult = mongoTemplate.updateFirst(query, update, Student.class);
        log.info("更新{}条记录",updateResult.getModifiedCount());
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值