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);

    }
相关推荐
麦兜*35 分钟前
MongoDB 6.0 新特性解读:时间序列集合与加密查询
数据库·spring boot·mongodb·spring·spring cloud·系统架构
程序员爱钓鱼6 小时前
Go语言实战案例 — 工具开发篇:编写高可用日志收集脚本
后端·mongodb·go
少男的脸红藏不住心事1 天前
GD32入门到实战35--485实现OTA
数据库·mongodb·nosql
易白2 天前
MongoDB服务1053错误、1067错误处理
mongodb
没有bug.的程序员2 天前
Redis vs Memcached vs MongoDB:深入对比与选型指南
java·redis·mongodb·memcached
麦兜*3 天前
MongoDB 性能调优:十大实战经验总结 详细介绍
数据库·spring boot·mongodb·spring cloud·缓存·硬件架构
csdn_aspnet3 天前
使用 MongoDB.Driver 在 C# .NETCore 中实现 Mongo DB 过滤器
mongodb·c#·.netcore
csdn_aspnet3 天前
使用 C# .NETCore 实现MongoDB
mongodb·c#·.netcore
weixin_471525785 天前
【单片机day01】
数据库·mongodb
数据库生产实战5 天前
MongoDB主从切换实战:如何让指定从库“精准”升级为主库?保姆级教程!
数据库·mongodb