MongoDB范圍查詢有哪些實(shí)踐案例

小樊
81
2024-10-31 11:38:00
欄目: 云計(jì)算

MongoDB的范圍查詢是一種非常強(qiáng)大的功能,它允許你根據(jù)文檔字段值的范圍來檢索數(shù)據(jù)。以下是一些常見的范圍查詢實(shí)踐案例:

1. 日期范圍查詢

假設(shè)你有一個(gè)博客系統(tǒng),并且想要查詢某個(gè)時(shí)間段內(nèi)發(fā)布的文章數(shù)量。

db.posts.countDocuments({
  createdAt: { $gte: new Date("2023-01-01"), $lte: new Date("2023-12-31") }
});

2. 數(shù)字范圍查詢

假設(shè)你有一個(gè)電商系統(tǒng),并且想要查詢某個(gè)價(jià)格范圍內(nèi)的商品數(shù)量。

db.products.countDocuments({
  price: { $gte: 100, $lte: 500 }
});

3. 字符串范圍查詢

假設(shè)你有一個(gè)社交媒體系統(tǒng),并且想要查詢某個(gè)字母范圍內(nèi)的用戶昵稱數(shù)量。

db.users.countDocuments({
  nickname: { $regex: /^A/, $options: "i" }
});

4. 地理位置范圍查詢

假設(shè)你有一個(gè)地圖應(yīng)用,并且想要查詢某個(gè)地理范圍內(nèi)的用戶數(shù)量。

db.users.countDocuments({
  location: { $geoWithin: { $box: [[-10, -10], [10, 10]] } }
});

5. 組合范圍查詢

假設(shè)你有一個(gè)電商系統(tǒng),并且想要查詢某個(gè)價(jià)格范圍內(nèi)且評(píng)分在某個(gè)范圍內(nèi)的商品數(shù)量。

db.products.countDocuments({
  price: { $gte: 100, $lte: 500 },
  rating: { $gte: 4, $lte: 5 }
});

6. 復(fù)合范圍查詢

假設(shè)你有一個(gè)博客系統(tǒng),并且想要查詢某個(gè)時(shí)間段內(nèi)且作者為特定用戶的文章數(shù)量。

db.posts.countDocuments({
  createdAt: { $gte: new Date("2023-01-01"), $lte: new Date("2023-12-31") },
  author: "authorName"
});

7. 排序和范圍查詢

假設(shè)你有一個(gè)電商系統(tǒng),并且想要查詢某個(gè)價(jià)格范圍內(nèi)的商品,并按價(jià)格排序。

db.products.find({
  price: { $gte: 100, $lte: 500 }
}).sort({ price: 1 });

8. 聚合管道中的范圍查詢

假設(shè)你有一個(gè)社交媒體系統(tǒng),并且想要查詢某個(gè)時(shí)間段內(nèi)且包含特定關(guān)鍵詞的用戶昵稱數(shù)量。

db.posts.aggregate([
  {
    $match: {
      createdAt: { $gte: new Date("2023-01-01"), $lte: new Date("2023-12-31") }
    }
  },
  {
    $addFields: {
      nickname: "$author"
    }
  },
  {
    $match: {
      nickname: { $regex: "keyword", $options: "i" }
    }
  },
  {
    $group: {
      _id: null,
      count: { $sum: 1 }
    }
  }
]);

這些案例展示了MongoDB范圍查詢的多樣性和靈活性,你可以根據(jù)具體需求靈活運(yùn)用這些查詢來滿足業(yè)務(wù)場景。

0