MongoDb常用代码及配置

MongoDb常用的语句:

详情见:https://blog.csdn.net/sinat_32502451/article/details/134342559

MongoDb建表:

MongoDB不需要建表,直接插入数据就会建表。

日期用 ISODate() 转换。

复制代码
db.getCollection("mongoDbTest").insert({userId:"dxcefg", status:1,  price:1.23, updateTime : ISODate("2022-02-13T07:06:25.371Z")})

添加 maven 依赖:

复制代码
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
        </dependency>

添加 application.yml 配置

复制代码
#数据库配置
spring:
  data:
    mongodb:
      # uri格式为:mongodb://用户名:密码@IP地址:端口/数据库
      uri: mongodb://xx:xxx@xx.xx.xx.xx:xx/xx

#mongodb打印日志
logging:
  level:
    org.springframework.data.mongodb.core.MongoTemplate: DEBUG

如果使用 properties文件,则是:

复制代码
spring.data.mongodb.uri=mongodb://xx:xxx@xx.xx.xx.xx:xx/xx
#mongodb打印日志
logging.level.org.springframework.data.mongodb.core.MongoTemplate=DEBUG

数据表对应的Bean:

@Document 指定表名。

复制代码
@Data
@Document(collection = "mongoDbTest")
public class MongoDbTest {

    private String userId;

    private int status;

    private BigDecimal price;

    private Date updateTime;

	//忽略 getter()、setter()
}

查询

复制代码
@Service
public class MongoDbService {

    @Resource
    private MongoTemplate mongoTemplate;

    public void testMongoDb() {

        Criteria criteria = new Criteria();
        Query query = new Query();
        criteria.and("status").is(1);
        query.addCriteria(criteria);
		
	//排序
        List<Sort.Order> orders = new ArrayList<Sort.Order>();
        orders.add(new Sort.Order(Sort.Direction.DESC, "updateTime"));
        query.with(Sort.by(orders));
        query.limit(1000);
	//查询
        List<MongoDbTest> list = mongoTemplate.find(query, MongoDbTest.class);
        System.out.println("MongoDbTest list:" + JSON.toJSONString(list));

    }
}

插入

复制代码
    public void testMongoDbInsert() {
        MongoDbTest mongoDbTest = new MongoDbTest();
        mongoDbTest.setUserId("081914");
        mongoDbTest.setPrice(BigDecimal.TEN);
        mongoDbTest.setStatus(2);
        mongoDbTest.setUpdateTime(new Date());

        //表名
        String collectionName = "mongoDbTest";
        //插入
        mongoTemplate.insert(mongoDbTest, collectionName);

    }

更新/修改

复制代码
    public void testMongoDbUpdate() {
        //要更新的数据
        Update update = Update.update("status", 789);
        //查询条件
        Query query = new Query();
        query.addCriteria(Criteria.where("userId").is("abc"));
        //表名
        String collectionName = "mongoDbTest";

        //更新符合条件的所有数据
        mongoTemplate.updateMulti(query, update, collectionName);

        //只更新一条数据
//        mongoTemplate.updateFirst(query, update, collectionName);

    }

删除

复制代码
    public void testMongoDbDelete() {

        //查询条件
        Query query = new Query();
        query.addCriteria(Criteria.where("userId").is("abcdefg"));
        //表名
        String collectionName = "mongoDbTest";
        //删除
        mongoTemplate.remove(query, collectionName);

    }
相关推荐
似水流年流不尽思念2 小时前
MongoDB 有哪些索引?适用场景?
后端·mongodb
麦兜*2 天前
MongoDB Atlas 云数据库实战:从零搭建全球多节点集群
java·数据库·spring boot·mongodb·spring·spring cloud
麦兜*2 天前
MongoDB 在物联网(IoT)中的应用:海量时序数据处理方案
java·数据库·spring boot·物联网·mongodb·spring
学编程的小程2 天前
突破局域网限制:MongoDB远程管理新体验
数据库·mongodb
清风6666663 天前
基于STM32的APP遥控视频水泵小车设计
stm32·单片机·mongodb·毕业设计·音视频·课程设计
最笨的羊羊3 天前
Debezium日常分享系列之:MongoDB 新文档状态提取
mongodb·debezium日常分享系列·新文档状态提取
王维志3 天前
LiteDB详解
数据库·后端·mongodb·sqlite·c#·json·database
张3蜂4 天前
MongoDB BI Connector 详细介绍与使用指南(手动安装方式,CentOS 7 + MongoDB 5.0.5)
数据库·mongodb·centos
csdn_aspnet4 天前
MongoDB C# .NetCore 驱动程序 序列化忽略属性
mongodb·c#·.netcore
麦兜*4 天前
MongoDB 与 GraphQL 结合:现代 API 开发新范式
java·数据库·spring boot·mongodb·spring·maven·graphql