MongoDB创建和查询视图(二)

目录

[基于lookup创建关联查询视图](#基于lookup创建关联查询视图)

创建带有默认字符序的视图

字符序

创建视图

视图中的字符序


基于$lookup创建关联查询视图

基于$lookup命令,通过集合的关联查询,用户可以创建基于两个集合的视图并查询视图数据。应用在构建查询时,无需每次构建和维护复杂的管道查询。

  • 构建用于创建视图的两个集合, inventory集合和orders集合

    db.inventory.insertMany([
    { prodId: 100, price: 20, quantity: 125},
    { prodId: 101, price: 10, quantity: 234},
    { prodId: 102, price: 15, quantity: 432},
    { prodId: 103, price: 17, quantity: 320}
    ])

    db.orders.insertMany([
    { orderId: 201, custid: 301, prodId: 100, numPurchased: 20},
    { orderId: 202, custid: 302, prodId: 101, numPurchased: 10},
    { orderId: 203, custid: 303, prodId: 102, numPurchased: 5},
    { orderId: 204, custid: 303, prodId: 103, numPurchased: 15},
    { orderId: 205, custid: 303, prodId: 103, numPurchased: 20},
    { orderId: 206, custid: 302, prodId: 102, numPurchased: 1},
    { orderId: 207, custid: 302, prodId: 101, numPurchased: 5},
    { orderId: 208, custid: 301, prodId: 100, numPurchased: 10},
    { orderId: 209, custid: 303, prodId: 103, numPurchased: 30}
    ])

  • 创建关联查询视图

    db.createView(
    "v_sales", // 视图名称
    "orders", // 基于orders集合创建视图
    [{
    lookup: {// 通过lookup查询inventory集合 from: "inventory", localField: "prodId", foreignField: "prodId", as: "inventoryDocs" } }, { project: { //指定输出字段
    _id: 0,
    prodId: 1,
    orderId: 1,
    numPurchased: 1,
    price: "inventoryDocs.price" } }, { unwind: "$price" //将price数组打平
    }])

  • 查询视图

    db.v_sales.find()

    /* 1 */
    {
    "orderId" : 201,
    "prodId" : 100,
    "numPurchased" : 20,
    "price" : 20
    },

    /* 2 */
    {
    "orderId" : 202,
    "prodId" : 101,
    "numPurchased" : 10,
    "price" : 10
    },
    ...

创建带有默认字符序的视图

字符序

字符集中字符串的排列顺序,用于指定字符串的比较规则,包括大小写比较规则,发音标记规则顺序等。

创建视图

Mongodb官网中,展示了一个带有默认字符序的视图

  • 创建一个不同cafe值的集合

    db.places.insertMany([
    { _id: 1, category: "café" },
    { _id: 2, category: "cafe" },
    { _id: 3, category: "cafE" }
    ])

  • 基于上述集合,创建一个视图,并指定字符序

    db.createView(
    "placesView",
    "places",
    [ { $project: {category: 1}}],
    {collation: { locale: "fr", strength: 1}}
    )

  • 查看视图数据

    db.placesView.countDocuments({ category: "cafe"})
    //结果返回3

视图中的字符序

  • 用户可以在创建视图时,指定字符序。如果没有指定字符序,视图默认的字符序就是简单的二进制字符序。视图并不会继承集合的默认字符序。

  • 视图中字符比较,使用默认的字符序。禁止尝试修改或覆盖字符序的操作

  • 基于已有view创建的视图,不可以指定与原始图不同的字符序

  • 在多个view中进行aggregation查询时,如lookup, graphLookup命令,使用的视图必须有相同的字符序。

    //基于placesView创建新的视图,指定不同的字符序,创建失败。
    db.createView(
    "placesView2",
    "placesView",
    [ { $project: {category: 1}}],
    {collation: { locale: "en", strength: 1}}
    )
    {
    "message" : "View test.placesView2 has conflicting collation with view test.placesView",
    "ok" : 0,
    "code" : 167,
    "codeName" : "OptionNotSupportedOnView"
    }

    //使用$lookup查询视图和不同字符序的集合,查询失败
    db.places.aggregate()
    .lookup({
    from: "placesView",
    localField: "category",
    foreignField: "category",
    as: "categoryViews"
    })
    {
    "message" : "Cannot override a view's default collationtest.placesView",
    "ok" : 0,
    "code" : 167,
    "codeName" : "OptionNotSupportedOnView"
    }

相关推荐
fzb5QsS1p2 小时前
MySQL 事务的二阶段提交是什么?
数据库·mysql
清风徐来QCQ6 小时前
Lombok/SSM/devTools
数据库
LaughingZhu6 小时前
Product Hunt 每日热榜 | 2026-04-05
前端·数据库·人工智能·经验分享·神经网络
2601_949814696 小时前
使用mysql报Communications link failure异常解决
数据库·mysql
搜佛说6 小时前
02-第2章-核心概念与架构
数据库·物联网·微服务·架构·边缘计算·iot
C'ᴇsᴛ.小琳 ℡8 小时前
高性能NoSQL
数据库·nosql
i220818 Faiz Ul8 小时前
动漫商城|基于springboot + vue动漫商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·动漫商城系统
iNgs IMAC8 小时前
redis 使用
数据库·redis·缓存
TDengine (老段)10 小时前
TDengine IDMP 可视化 —— 面板
大数据·数据库·人工智能·物联网·ai·时序数据库·tdengine
卓怡学长10 小时前
m315基于java的水果网上商城的开发与设计
java·数据库·spring·tomcat·maven·intellij-idea