mongodb3.4创建只读视图实例

来源:互联网 发布:包天下网络怎么赚钱 编辑:程序博客网 时间:2024/05/21 19:27
/**
* 这是一个MongoDB3.4创建视图的实例
* (如果需要高亮显示,可以将本页文本copy到支持高亮的编辑器中打开)

* 准备工作
* 首先创建一个名为test的数据库
* 在test数据库中创建两个集合,分别为users和groups
* 分别为两个数据集合录入若干数据:如下面db.users.find()和db.groups.find()查询结果所示
*
* 本实例分别演示了单集合视图和多集合视图的创建和查询的过程

* 通过本实例可以更直观的了解MongoDB3.4提供的只读视图功能所带来的便利
*/

// linux下输入mongo进入mongodb的命令行模式

[root@~]# mongo

//进入test库

> use test


/**
* 查看所有数据集
*/
> show collections
groups
users
//查看用户表中数据(预设)
> db.users.find() 
{ "_id" : ObjectId("5852428b50df188fee654180"), "username" : "php_man", "sex" : 1, "age" : 33, "group_id" : ObjectId("5852401c50df188fee654176") }
{ "_id" : ObjectId("585242ab50df188fee654182"), "username" : "java_girl", "sex" : 2, "age" : 27, "group_id" : ObjectId("5852401c50df188fee654176") }
{ "_id" : ObjectId("5852436150df188fee654184"), "username" : "js_man", "sex" : 1, "age" : 28, "group_id" : ObjectId("5852405d50df188fee654178") }
{ "_id" : ObjectId("5852439e50df188fee654186"), "username" : "css_girl", "sex" : 2, "age" : 26, "group_id" : ObjectId("5852405d50df188fee654178") }
//查看用户组表中数据(预设)
> db.groups.find() 
{ "_id" : ObjectId("5852401c50df188fee654176"), "groupname" : "后端组", "zuzhang" : ObjectId("5852428b50df188fee654180") }

{ "_id" : ObjectId("5852405d50df188fee654178"), "groupname" : "前端组", "zuzhang" : ObjectId("5852436150df188fee654184") }


/**
* 创建单集合视图 
* @db.createView(视图名称,集合名称,条件)
*/
> db.createView("man","users",{$match:{sex:1}})
{ "ok" : 1 }

// 查询视图,和集合的方式完全一样
> db.man.find()
{ "_id" : ObjectId("5852428b50df188fee654180"), "username" : "php_man", "sex" : 1, "age" : 33, "type" : "php" }
{ "_id" : ObjectId("5852436150df188fee654184"), "username" : "js_man", "sex" : 1, "age" : 28, "type" : "h5" }


/**

* 创建多集合视图一
* 视图说明:查询用户组信息 时 关联查询用户信息
* @createView("视图名称","主查询集合",[{$lookup:{from:"关联集合",localField:"关联字段",foreignField:"外键",as:"为关联集合命名"}},{$project:{查询结果显示条件}}])
*/
> db.createView("group_user","groups",[{$lookup:{from:"users",localField:"zuzhang",foreignField:"_id",as:"zuzhang_info"}},{$project:{"zuzhang_info._id":0}}])
{ "ok" : 1 }

> db.group_user.find()
{ "_id" : ObjectId("5852401c50df188fee654176"), "groupname" : "后端组", "zuzhang" : ObjectId("5852428b50df188fee654180"), "zuzhang_info" : [ { "username" : "php_man", "sex" : 1, "age" : 33, "type" : "php" } ] }
{ "_id" : ObjectId("5852405d50df188fee654178"), "groupname" : "前端组", "zuzhang" : ObjectId("5852436150df188fee654184"), "zuzhang_info" : [ { "username" : "js_man", "sex" : 1, "age" : 28, "type" : "h5" } ] }


/**

* 创建多集合视图二
*
* 视图说明:查询用户信息 时 关联查询用户组信息 
* createView("视图名称","主查询集合",[{$lookup:{from:"关联集合",localField:"关联字段",foreignField:"外键",as:"为关联集合命名"}},{$project:{查询结果显示条件}}])
* @author wangguosheng
*/
> db.createView("user_group","users",[{$lookup:{from:"groups",localField:"group_id",foreignField:"_id",as:"group_info"}},{$project:{"group_info._id":0}}])
{ "ok" : 1 }


> db.user_group.find()
{ "_id" : ObjectId("5852428b50df188fee654180"), "username" : "php_man", "sex" : 1, "age" : 33, "group_id" : ObjectId("5852401c50df188fee654176"), "group_info" : [ { "groupname" : "后端组", "zuzhang" : ObjectId("5852428b50df188fee654180") } ] }
{ "_id" : ObjectId("585242ab50df188fee654182"), "username" : "java_girl", "sex" : 2, "age" : 27, "group_id" : ObjectId("5852401c50df188fee654176"), "group_info" : [ { "groupname" : "后端组", "zuzhang" : ObjectId("5852428b50df188fee654180") } ] }
{ "_id" : ObjectId("5852436150df188fee654184"), "username" : "js_man", "sex" : 1, "age" : 28, "group_id" : ObjectId("5852405d50df188fee654178"), "group_info" : [ { "groupname" : "前端组", "zuzhang" : ObjectId("5852436150df188fee654184") } ] }
{ "_id" : ObjectId("5852439e50df188fee654186"), "username" : "css_girl", "sex" : 2, "age" : 26, "group_id" : ObjectId("5852405d50df188fee654178"), "group_info" : [ { "groupname" : "前端组", "zuzhang" : ObjectId("5852436150df188fee654184") } ] }


/**

* 创建多集合视图三
* 视图说明:查询用户信息 时 关联查询用户组信息 并将 用户组的组长信息关联查询出来 
* 该视图比较特殊的地方是将两个已存在的视图关联起来创建成为一个新的视图

* @createView("视图名称","主查询集合",[{$lookup:{from:"关联集合",localField:"关联字段",foreignField:"外键",as:"为关联集合命名"}},{$project:{查询结果显示条件}}])
*/
> db.createView("user_group_zuzhang","user_group",[{$lookup:{from:"group_user",localField:"group_id",foreignField:"_id",as:"group_info"}},{$project:{"user_group.group_info":0}}])
{ "ok" : 1 }


> db.user_group_zuzhang.find()
{ "_id" : ObjectId("5852428b50df188fee654180"), "username" : "php_man", "sex" : 1, "age" : 33, "group_id" : ObjectId("5852401c50df188fee654176"), "group_info" : [ { "_id" : ObjectId("5852401c50df188fee654176"), "groupname" : "后端组", "zuzhang" : ObjectId("5852428b50df188fee654180"), "zuzhang_info" : [ { "username" : "php_man", "sex" : 1, "age" : 33, "group_id" : ObjectId("5852401c50df188fee654176") } ] } ] }
{ "_id" : ObjectId("585242ab50df188fee654182"), "username" : "java_girl", "sex" : 2, "age" : 27, "group_id" : ObjectId("5852401c50df188fee654176"), "group_info" : [ { "_id" : ObjectId("5852401c50df188fee654176"), "groupname" : "后端组", "zuzhang" : ObjectId("5852428b50df188fee654180"), "zuzhang_info" : [ { "username" : "php_man", "sex" : 1, "age" : 33, "group_id" : ObjectId("5852401c50df188fee654176") } ] } ] }
{ "_id" : ObjectId("5852436150df188fee654184"), "username" : "js_man", "sex" : 1, "age" : 28, "group_id" : ObjectId("5852405d50df188fee654178"), "group_info" : [ { "_id" : ObjectId("5852405d50df188fee654178"), "groupname" : "前端组", "zuzhang" : ObjectId("5852436150df188fee654184"), "zuzhang_info" : [ { "username" : "js_man", "sex" : 1, "age" : 28, "group_id" : ObjectId("5852405d50df188fee654178") } ] } ] }
{ "_id" : ObjectId("5852439e50df188fee654186"), "username" : "css_girl", "sex" : 2, "age" : 26, "group_id" : ObjectId("5852405d50df188fee654178"), "group_info" : [ { "_id" : ObjectId("5852405d50df188fee654178"), "groupname" : "前端组", "zuzhang" : ObjectId("5852436150df188fee654184"), "zuzhang_info" : [ { "username" : "js_man", "sex" : 1, "age" : 28, "group_id" : ObjectId("5852405d50df188fee654178") } ] } ] }


// 查看所有数据集 

> show collections
group_user
groups
man
system.views
user_group
user_group_zuzhang
users


/**

* 查看创建的视图
*
* 视图中并不存放数据,而是将视图的相关信息及关联数据集的规则放到system.views中
* 查询视图的时候实际上是通过查询多个数据集,然后将结果汇集到聚合管道(Aggregation Pipeline),最后将数据组装到一起再返回
*/
> db.system.views.find()
{ "_id" : "test.man", "viewOn" : "users", "pipeline" : [ { "$match" : { "sex" : 1 } } ] }
{ "_id" : "test.group_user", "viewOn" : "groups", "pipeline" : [ { "$lookup" : { "from" : "users", "localField" : "zuzhang", "foreignField" : "_id", "as" : "zuzhang_info" } }, { "$project" : { "zuzhang_info._id" : 0 } } ] }
{ "_id" : "test.user_group", "viewOn" : "users", "pipeline" : [ { "$lookup" : { "from" : "groups", "localField" : "group_id", "foreignField" : "_id", "as" : "group_info" } }, { "$project" : { "group_info._id" : 0 } } ] }
{ "_id" : "test.user_group_zuzhang", "viewOn" : "user_group", "pipeline" : [ { "$lookup" : { "from" : "group_user", "localField" : "group_id", "foreignField" : "_id", "as" : "group_info" } }, { "$project" : { "user_group.group_info" : 0 } } ] }