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

    }
相关推荐
葫芦和十三1 天前
图解 MongoDB 12|索引与查询优化地图:一条主线,三个判断轴
后端·mongodb·agent
葫芦和十三2 天前
图解 MongoDB 11|慢查询排查闭环:从 Profile 到 explain 的分层路径
后端·mongodb·agent
葫芦和十三2 天前
图解 MongoDB 09|explain 再读:从 queryPlanner 到 executionStats
后端·mongodb·agent
葫芦和十三2 天前
图解 MongoDB 10|覆盖查询:让索引把活干完,根本不用回表
后端·mongodb·agent
葫芦和十三3 天前
图解 MongoDB 08|ESR 原则:复合索引的字段顺序怎么定
后端·mongodb·agent
葫芦和十三4 天前
图解 MongoDB 07|索引类型:七种索引,七种访问形状
后端·mongodb·agent
葫芦和十三4 天前
图解 MongoDB 06|模式演进:无 schema 是优势还是债
后端·mongodb·agent
葫芦和十三5 天前
图解 MongoDB 05|文档模型设计:内嵌 vs 引用,反范式不是免费午餐
后端·mongodb·agent
葫芦和十三5 天前
图解 MongoDB 03|CRUD 全链路:一条 find 怎么穿过 WiredTiger
后端·mongodb·agent
葫芦和十三6 天前
图解 MongoDB 04|索引模型:每建一个索引,就是在 B+-tree 森林里多栽一棵
后端·mongodb·agent