校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > mongoDB使用投影剔除‘額外’字段的操作過程

mongoDB使用投影剔除‘額外’字段的操作過程

熱門標簽:智能外呼系統官網 外呼線路資源屬于電信業務嗎 小裙科技電銷機器人怎樣 呼和浩特外呼系統原理是什么 長沙電銷外呼防封卡是什么 河南電話外呼系統招商 crm外呼系統聯系方式 內蒙古營銷智能外呼系統哪個好 青白江400企業電話申請

簡介

實際開發過程中,為便于開發人員定位問題,常存在多個額外的字段。例如:增加createdAt、updatedAt字段以查看數據的創建和更改時間。而對于客戶端而言,無需知道其存在。針對以上情況,本文詳細介紹了“額外”字段的用途以及處理過程。

技術棧

  • mongodb 4.0.20
  • mongoose 5.10.7

1  "額外"字段是什么

1.1 "額外"是指與業務無關

mongodb中,collection中存儲的字段并不僅僅有業務字段。有些情況下,會存儲多余的字段,以便于開發人員定位問題、擴展集合等。

額外的含義是指 和業務無關、和開發相關的字段。這些字段不需要被用戶所了解,但是在開發過程中是至關重要的。

1.2 產生原因

產生額外字段的原因是多種多樣的。

  • 如使用mongoose插件向db中插入數據時,會默認的生成_id、__v字段
  • 如軟刪除,則是通過控制is_deleted實現..

2 額外字段的分類

額外字段的產生原因有很多,可以以此進行分類。

2.1 _id、__v字段

產生原因:以mongoose為例,通過schema->model->entity向mongodb中插入數據時,該數據會默認的增加_id、__v字段。

_id字段是由mongodb默認生成的,用于文檔的唯一索引。類型是ObjectID。mongoDB文檔定義如下:


MongoDB creates a unique index on the _id field during the creation of a collection. The _id index prevents clients from inserting two documents with the same value for the _id field. You cannot drop this index on the _id field.

__v字段是由mongoose首次創建時默認生成,表示該條doc的內部版本號。


The versionKey is a property set on each document when first created by Mongoose. This keys value contains the internal revision of the document. The versionKey option is a string that represents the path to use for versioning. The default is __v.

2.2 createdAt、updatedAt字段

createdAt、updatedAt字段是通過timestamp選項指定的,類型為Date。


The timestamps option tells mongoose to assign createdAt and updatedAt fields to your schema. The type assigned is Date.By default, the names of the fields are createdAt and updatedAt. Customize the field names by setting timestamps.createdAt and timestamps.updatedAt.

2.3 is_deleted字段

is_deleted字段是實現軟刪除一種常用的方式。在實際業務中,出于各種原因(如刪除后用戶要求再次恢復等),往往采用的軟刪除,而非物理刪除。

因此,is_deleted字段保存當前doc的狀態。is_deleted字段為true時,表示當前記錄有效。is_deleted字段為false時,表示當前記錄已被刪除。

3 額外字段相關操作

3.1 額外字段生成

_id字段是必選項;__v、createdAt、updatedAt字段是可配置的;status字段直接加在s對應的chema中。相關的schema代碼如下:

isdeleted: {
 type: String,
 default:true,
 enum: [true, false],
},
id: {
 type: String,
 index: true,
 unqiue: true,
 default:uuid.v4(),
}},
{timestamps:{createdAt:'docCreatedAt',updatedAt:"docUpdatedAt"},versionKey:false});

通過配置schema中的timestamps選項,可以將createdAt和updatedAt字段加入到doc中。在創建和更新doc時,這兩個字段無需傳入,就會自動變化。

3.2 額外字段清理

通過3.1可以明確的產生若干額外字段,但是客戶端調用接口并返回時,這些字段是無需得知的。因此需對額外字段進行清理。清理方式分為投影和過濾。

以query、update接口為例。其中query接口用于:1、查詢指定字段 2、查詢全部字段 3、分頁排序查詢。update接口用于更新并返回更新后的數據。

根據是否需要指定字段、和collection中有無內嵌的情況劃分,一共有4類。接著針對這4種情況進行分析。

1、有指定字段、無內嵌

2、無指定字段、無內嵌

3、有指定字段、有內嵌

4、無指定字段、有內嵌

3.2.1 投影

有指定字段是指在查詢時指定查詢字段,而無需全部返回。mongo中實現指定的方式是投影 (project) 。mongo官方文檔中定義如下:


The $project takes a document that can specify the inclusion of fields, the suppression of the _id field, the addition of new fields, and the resetting of the values of existing fields. Alternatively, you may specify the exclusion of fields.

$project可以做3件事:

1.指定包含的字段、禁止_id字段、添加新字段

2.重置已存在字段的值

3.指定排除的字段

我們只需關注事情1、事情3。接著查看mongoose中對project的說明:


When using string syntax, prefixing a path with - will flag that path as excluded. When a path does not have the - prefix, it is included. Lastly, if a path is prefixed with +, it forces inclusion of the path, which is useful for paths excluded at the schema level.

A projection must be either inclusive or exclusive. In other words, you must either list the fields to include (which excludes all others), or list the fields to exclude (which implies all other fields are included). The _id field is the only exception because MongoDB includes it by default.

注意:此處指query "projection"

mongoose表明:投影要么是全包含,要么是全剔除。不允許包含和剔除同時存在。但由于

_id是MongoDB默認包含的,因此_id是個例外。

select project投影語句組裝代碼:

 /**
 * 添加通用篩選條件
 * @param {*} stat 已裝配的篩選語句 
 * @param {*} collection collectionName
 * @return {*} 組裝完成的語句
 */
 function addCommonSelectCond(stat,collection)
 {
 if(typeof(stat)!="object") return;

 stat["_id"] = 0;
 stat["__v"] = 0;
 stat["status"] = 0;
 stat["docCreatedAt"] = 0;
 stat["docUpdatedAt"] = 0;

 var embeddedRes = hasEmbedded(collection);
 if(embeddedRes["isEmbedded"])
 {
 for(var item of embeddedRes["embeddedSchema"])
 {
 stat[item+"._id"] = 0;
 stat[item+".__v"] = 0;
 stat[item+".status"] = 0;
 stat[item+".docCreatedAt"] = 0; 
 stat[item+".docUpdatedAt"] = 0; 
 }
 }
 return stat;
 }

3.2.2 過濾

通過findOneAndupdate、insert、query等返回的doc對象中(已經過lean或者toObject處理),是數據庫中真實狀態。因此需要對產生的doc進行過濾,包括doc過濾和內嵌文檔過濾。

/**
 * 處理自身及內嵌的表
 * @param {*} collection 查詢的表
 * @param {*} doc 已查詢出的結果
 * @returns doc 清理后的結果
 */
static clearDoc(collection,doc){
 if(doc === undefined || doc === null || typeof doc != "object" ) return null;
 doc = this.clearExtraField(doc);

 var res = hasEmbedded(collection);
 if(res["isEmbedded"])
 {
 let arr = res["embeddedSchema"];
 for(var item of arr){
 if(doc[item])
 doc[item] = this.clearArray(doc[item]);
 }
 }
 return doc;
}

static clearExtraField(doc){
 if(doc === null || typeof doc != "object")
 return;
 
 var del = delete doc["docCreatedAt"]
 delete doc["docUpdatedAt"]
 delete doc["_id"]
 delete doc["__v"]
 delete doc["status"];
 if(!del) return new Error("刪除額外字段出錯");

 return doc;
}

static clearArray(arr)
{
 if(!Array.isArray(arr)) return;

 var clearRes = new Array();
 for(var item of arr){
 clearRes.push(this.clearExtraField(item));
 }
 return clearRes;
}

細心的讀者已經發現了,投影和過濾的字段內容都是額外字段。那什么情況下使用投影,什么情況下使用過濾呢?

關于這個問題,筆者的建議是如果不能確保額外字段被剔除掉,那就采取雙重認證:查詢前使用投影,查詢后使用過濾。

4 總結

本文介紹了實際業務中往往會產生額外字段。而在mongoDB中,"消除"額外字段的手段主要是投影、過濾。

以使用頻率最高的查詢接口為例,整理如下:

指定選項 內嵌選項 查詢前投影 查詢后過濾
有指定 無內嵌 ×
有指定 有內嵌 ×
無指定 無內嵌 ×
無指定 有內嵌 ×

因此,筆者建議無論schema中是否配置了options,在查詢時組裝投影語句,查詢后進行結果過濾。這樣保證萬無一失,

額外字段才不會漏到客戶端**。

到此這篇關于mongoDB使用投影剔除‘額外'字段的文章就介紹到這了,更多相關mongoDB用投影剔除額外字段內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:菏澤 安順 黃石 呼倫貝爾 楚雄 池州 白山 舟山

巨人網絡通訊聲明:本文標題《mongoDB使用投影剔除‘額外’字段的操作過程》,本文關鍵詞  mongoDB,使用,投影,剔除,額外,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mongoDB使用投影剔除‘額外’字段的操作過程》相關的同類信息!
  • 本頁收集關于mongoDB使用投影剔除‘額外’字段的操作過程的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    **网站欧美大片在线观看| 国产精品国产自产拍高清av| 国产suv精品一区二区三区| 亚洲黄网站在线观看| 久久伊99综合婷婷久久伊| 91久久精品一区二区| 国产九色sp调教91| 日韩电影在线观看网站| 亚洲欧美日韩系列| 国产欧美一区二区精品久导航| 欧美日韩一级片网站| 99久久综合99久久综合网站| 久久精品国产色蜜蜜麻豆| 夜夜嗨av一区二区三区网页| 国产精品美女久久久久aⅴ| 91麻豆精品91久久久久久清纯| 色综合久久久久综合体桃花网| 国产成人精品综合在线观看| 青青草97国产精品免费观看无弹窗版| 亚洲女人的天堂| 国产精品传媒在线| 国产欧美一区二区三区沐欲| 欧美草草影院在线视频| 91精品视频网| 欧美精品亚洲一区二区在线播放| 日本精品裸体写真集在线观看| 成人综合在线观看| 国产91丝袜在线观看| 国产成人午夜精品影院观看视频| 蓝色福利精品导航| 久久激情五月婷婷| 日本vs亚洲vs韩国一区三区二区 | 岛国一区二区三区| 国产一区二区久久| 国产一区视频网站| 国产精品一二三四区| 国产一区免费电影| 国产成人亚洲综合色影视| 国产精品一区不卡| 成人动漫一区二区在线| proumb性欧美在线观看| 成人精品亚洲人成在线| 成人国产精品免费观看动漫 | 欧美影院一区二区| 精品视频在线免费观看| 这里只有精品免费| 欧美zozozo| 久久久99精品免费观看| 国产日产欧美精品一区二区三区| 国产精品区一区二区三| 中文字幕日韩精品一区| 夜夜爽夜夜爽精品视频| 日韩激情视频网站| 国产在线一区观看| 成人精品免费网站| 在线一区二区三区四区五区| 欧美日韩一区精品| 日韩欧美国产精品| 国产亚洲一区二区在线观看| 在线一区二区三区做爰视频网站| 欧美aⅴ一区二区三区视频| 蜜臀av一级做a爰片久久| 狠狠色狠狠色合久久伊人| 国产精一区二区三区| 91性感美女视频| 欧美三级乱人伦电影| 日韩欧美亚洲另类制服综合在线| 久久色成人在线| 亚洲四区在线观看| 午夜一区二区三区视频| 美腿丝袜在线亚洲一区| 成人一区在线观看| 欧美色爱综合网| 久久先锋影音av鲁色资源| 亚洲欧洲精品天堂一级| 午夜国产精品影院在线观看| 国产一区二区三区久久悠悠色av| 99久久伊人精品| 日韩视频一区二区三区在线播放| 久久精品人人做| 亚洲在线一区二区三区| 国产一区在线精品| 欧美日韩精品欧美日韩精品| 久久综合视频网| 亚洲777理论| av中文字幕亚洲| 精品蜜桃在线看| 亚洲欧美另类久久久精品2019| 麻豆精品久久精品色综合| 91性感美女视频| 久久久久久久一区| 日韩激情在线观看| 色综合激情久久| 国产亚洲精品bt天堂精选| 爽好多水快深点欧美视频| av亚洲精华国产精华| 日韩三级高清在线| 亚洲一区二区五区| 成人高清在线视频| 日韩精品资源二区在线| 亚洲综合精品久久| 成人动漫av在线| 日韩欧美国产一区二区在线播放 | 欧美日本精品一区二区三区| 日本一区二区免费在线观看视频| 日韩黄色一级片| 欧美性猛片aaaaaaa做受| 国产精品欧美综合在线| 国产一区二区在线观看免费 | 欧美撒尿777hd撒尿| 一区精品在线播放| 粉嫩高潮美女一区二区三区| 日韩午夜激情视频| 香蕉乱码成人久久天堂爱免费| 99久久精品国产一区| 国产亚洲成aⅴ人片在线观看 | 91麻豆精品91久久久久久清纯| 亚洲裸体在线观看| 成人午夜大片免费观看| 日韩欧美电影一二三| 亚洲成人精品在线观看| 欧美午夜在线观看| 亚洲三级免费观看| 99精品国产一区二区三区不卡 | 亚洲h动漫在线| 91老师国产黑色丝袜在线| 欧美国产精品一区二区三区| 国产精品亚洲一区二区三区妖精 | 欧美视频在线一区| 亚洲一区二区综合| 在线视频一区二区三| 亚洲精品视频在线看| 91视频在线观看| 一区二区三区免费| 欧美在线免费观看视频| 亚洲福利视频一区| 3d成人动漫网站| 美女尤物国产一区| 26uuu亚洲| 国产999精品久久久久久绿帽| 亚洲精品在线网站| 国产裸体歌舞团一区二区| 久久亚洲私人国产精品va媚药| 国产精品综合视频| 国产精品视频免费看| 91亚洲永久精品| 亚洲综合一区二区| 欧美日韩高清一区二区三区| 日韩精品电影一区亚洲| 欧美一二三四区在线| 国产麻豆一精品一av一免费 | 欧美日韩一区二区在线视频| 三级久久三级久久| 精品奇米国产一区二区三区| 国产一区在线精品| 国产精品久久久久久户外露出 | 午夜伊人狠狠久久| 欧美电影免费观看高清完整版| 国产精品一区二区果冻传媒| 国产精品久久久久久久久免费樱桃 | 亚洲免费伊人电影| 欧美日本在线一区| 国产一区日韩二区欧美三区| 国产精品欧美精品| 欧美日精品一区视频| 麻豆91免费看| 亚洲欧洲精品一区二区三区| 精品视频一区三区九区| 琪琪一区二区三区| 国产精品久久久一本精品 | 麻豆精品国产91久久久久久| 久久精品视频一区二区三区| 色综合久久九月婷婷色综合| 青青草国产精品亚洲专区无| 国产日韩欧美高清| 欧美日韩第一区日日骚| 国产在线不卡一区| 亚洲一区二区精品视频| 精品欧美乱码久久久久久1区2区| 波多野结衣在线一区| 日本不卡一区二区| 国产精品久久久久aaaa| 日韩一本二本av| www.日韩大片| 久草精品在线观看| 一区二区三区av电影| 2020国产成人综合网| 日本福利一区二区| 国产乱码精品一品二品| 亚洲成人福利片| 国产精品欧美一区二区三区| 欧美男人的天堂一二区| 成人福利视频网站| 麻豆91在线播放免费| 亚洲综合激情网| 国产精品狼人久久影院观看方式| 69久久夜色精品国产69蝌蚪网| av动漫一区二区| 国产一级精品在线| 日本在线不卡视频|