午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > 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使用投影剔除‘額外’字段的操作過程的相關信息資訊供網民參考!
  • 推薦文章
    丁香啪啪综合成人亚洲| 欧美一级搡bbbb搡bbbb| 一区二区三区 欧美| 亚洲欧洲日产国码二区| 黄色一级视频片| 亚洲欧洲综合另类| 少妇网站在线观看| 欧美老肥妇做.爰bbww| 亚洲av成人片无码| 日韩h在线观看| 日本免费观看视| 91国内在线视频| 亚洲乱色熟女一区二区三区| 91美女片黄在线观| 国产精品亚洲第一| 欧美视频在线第一页| 亚洲欧美另类久久久精品2019| 亚洲无吗一区二区三区| 欧美日韩国产不卡| 亚洲自拍偷拍一区二区| 在线观看中文字幕亚洲| 136福利视频导航| 91最新在线免费观看| 国产69精品久久久久毛片| 99精品一级欧美片免费播放| 一区二区三区在线免费播放| 中国老熟女重囗味hdxx| 欧美成人r级一区二区三区| 亚洲国产精品成人无久久精品| 国内精品在线一区| 日韩高清一区在线| 日本一本草久p| 国产欧美一区二区精品仙草咪| 日本成人中文字幕在线| 91精品国产免费| 麻豆一区二区三区精品视频| 色综合久久88| 日韩电影在线一区| 国产一二三四区在线观看| 狠狠久久五月精品中文字幕| 免费看的黄色网| 日韩亚洲欧美中文在线| 内射后入在线观看一区| 亚洲蜜桃在线| 色素色在线综合| 欧美疯狂做受xxxx高潮| 国产精品一区二区在线播放| 欧美日韩综合视频网址| 国产国语性生话播放| 最近2019中文免费高清视频观看www99| 久久久久久久久久久网站| 亚洲天堂一区二区在线观看| 久久伊人免费视频| 中文字幕精品av| 亚洲综合视频在线| 香蕉人妻av久久久久天天| 91国视频在线| 中文字幕视频在线免费欧美日韩综合在线看| 中文字幕人成不卡一区| 午夜视频一区在线观看| 日韩三级免费观看| 精品丝袜一区二区三区| 亚洲精品午夜精品| 日韩一区二区在线看片| 亚洲福利视频三区| 中文字幕网址在线| 黄色一级大片在线免费观看| www.四虎精品| 国产精品九九九| 粉嫩av一区二区三区免费野| 欧美又粗又大又爽| 亚洲h在线观看| 久久综合999| 成人无码一区二区三区| 网站一区二区三区| 久久精品ww人人做人人爽| 成人av资源在线播放| 一本一生久久a久久精品综合蜜 | 亚洲精品在线看| 欧美一区二区三区艳史| 欧美区二区三区| 精品免费在线观看| 国产精品视频一二| 久久久国产精品午夜一区ai换脸| 91video| 一级做a爰片久久| 91入口在线观看| 成人国产精品日本在线| 在线播放日韩专区| 日韩欧美主播在线| 久久无码av三级| 天堂网一区二区| 欧美午夜激情影院| 三区四区在线观看| 中文字幕被公侵犯的漂亮人妻| 45www国产精品网站| 欧美日韩在线免费观看| 国产精品理论在线观看| av不卡免费电影| 少妇一级淫片免费放中国| 少妇网站在线观看| 91猫先生在线| 精品人妻一区二区三区日产| 日韩aⅴ视频一区二区三区| 国产伦精品一区二区三毛| 国产精品美女www| 国产精品久久久久久久久快鸭 | 日韩片之四级片| 欧美日韩xxx| 国产精品伊人日日| 欧美日韩一区二区视频在线| 中文字幕一区二区三区人妻在线视频 | 亚洲激情电影中文字幕| 国产成人精品视频在线观看| 成人午夜在线观看| 久久精品国产精品青草色艺| 日韩激情视频| 国产一区二区在线免费| 日本国产在线观看| 最新中文字幕久久| 国产在线不卡av| 可以免费观看的毛片| 久久99国产精品尤物| 日本精品一区二区三区高清| 国产精品视频自在线| 免费成人蒂法网站| www.超碰在线.com| 亚洲永久精品国产| 亚洲网站视频福利| 国产福利精品av综合导导航| 91sa在线看| av电影成人| 国产精品亚洲a| www插插插无码免费视频网站| 欧美bbbbb性bbbbb视频| 免费成人深夜夜行p站| 人妻少妇一区二区三区| 3d动漫精品啪啪1区2区免费| 久久久精品动漫| 国产精品18p| 2020国产精品久久精品美国| 欧美日韩综合在线免费观看| 国产日韩综合av| 一区二区三区欧美激情| 日韩欧美亚洲另类制服综合在线| 久久这里有精品| 国产精品扒开腿做爽爽爽男男 | 免费成人在线视频网站| 中文字幕激情视频| 亚洲免费在线观看| 欧美一区二区网站| 欧美大学生性色视频| 91久久精品国产91久久性色tv| 7777精品久久久大香线蕉小说| 欧美婷婷精品激情| 秋霞成人午夜伦在线观看| 男女男精品视频站| 国产精品露出视频| 日韩中文在线中文网在线观看| 一区二区三区国产| 九色porny丨国产精品| 欧美一级视频免费观看| 性生活在线视频| 一区二区视频在线免费| 国产成人综合一区二区三区| 亚洲第一精品夜夜躁人人躁| 亚洲蜜臀av乱码久久精品蜜桃| 蜜芽一区二区三区| 国产黄色免费视频| 中文字幕日韩三级片| 成人区一区二区| 91在线观看免费观看| 深夜福利91大全| 欧美视频中文一区二区三区在线观看 | 免费看成人午夜电影| 欧美国产日本高清在线| 日韩欧美亚洲一区二区| 一区二区三区四区中文字幕| 国产美女精品人人做人人爽| 波多野结衣家庭主妇| 亚洲a v网站| 欧美一级黄色影院| 色一情一乱一伦一区二区三区丨| 97国产成人精品视频| 日韩经典一区二区三区| 一本到不卡精品视频在线观看| 99久久精品国产一区| 手机看片福利永久| 久久精品无码av| 99久久99久久精品免费看小说. | 久久久免费高清电视剧观看| 日韩精品一区二区三区视频播放| 亚洲最大色网站| 久久成人麻豆午夜电影| 99精品免费观看| 人人干人人干人人干| 天堂久久精品忘忧草| 免费成年人高清视频| wwwwww欧美| 久久伊人一区| 91在线观看免费高清| 97人洗澡人人免费公开视频碰碰碰| 亚洲精品视频播放| 欧美一区二区三区四区久久 | 亚洲成人中文字幕| 色综合激情五月| 国产精品久久久久三级| 盗摄精品av一区二区三区| 日本中文在线一区| 午夜精品久久久久久久第一页按摩| 日本网站在线免费观看| 成人欧美一区二区三区黑人一 | 中文在线观看免费视频| 另类小说第一页| 国产va亚洲va在线va| 吴梦梦av在线| 五月婷婷综合色| 免费观看国产成人| 国产精品高清一区二区三区| 国产精品视频公开费视频| 久久久久国产视频| 久久国产精品久久久久| 国产性猛交xxxx免费看久久| 精品国产一区二区三区四区四| 欧美午夜精品免费| 在线区一区二视频| 色婷婷综合久色| 天天综合日日夜夜精品| 一区二区三区日韩在线观看| 国产精品二区一区二区aⅴ污介绍| 91视频91自| av电影一区二区| 白白色 亚洲乱淫| 国产不卡在线视频| 国产成人综合网| 激情深爱一区二区| 国产综合久久久久影院| 加勒比av一区二区| 国产又粗又猛又爽又黄91精品| 久久黄色级2电影| 久久se精品一区二区| 日本视频在线一区| 麻豆精品一区二区综合av| 日韩av二区在线播放| 老妇喷水一区二区三区| 天堂va蜜桃一区二区三区 | 欧美老女人在线视频| 欧美精品制服第一页| 欧美日韩国产成人在线观看| 欧美激情xxxx| 98精品国产高清在线xxxx天堂| 97色在线播放视频| 国产精品久久久久久中文字| 国产日产亚洲精品| 91传媒视频在线观看| 国产一区免费观看| 日本欧洲国产一区二区| 在线成人性视频| 国产欧美久久久久| heyzo国产| 激情五月俺来也| 秘密基地免费观看完整版中文 | 椎名由奈av一区二区三区| 亚洲免费在线观看| 懂色av一区二区三区| 在线观看av一区二区| 日韩午夜精品视频| 亚洲裸体xxxx| 欧美成人剧情片在线观看| 97免费中文视频在线观看| 国产精品高清在线| 一区二区在线观看免费视频播放 | 亚欧洲乱码视频| 波多野结衣精品在线| 国内精品国产三级国产在线专| 簧片在线免费看| 丁香亚洲综合激情啪啪综合| 精品国产一区二区三区久久久狼| 成熟老妇女视频| 青青草国产成人av片免费| 日韩国产欧美区| 激情婷婷综合网| 国产揄拍国内精品对白| 日韩中文字幕在线| 日批视频在线看| 91日韩精品一区| 国产精品高潮呻吟视频| 亚洲一级片在线播放| 亚洲美女一区二区三区| 九色91在线视频| 91色在线播放| 亚洲免费av网址| 国产精品成人免费一区二区视频| 一区二区中文视频| 中文字幕一区综合| 久久成人免费日本黄色| 中文字幕日韩欧美在线视频| 日韩精品人妻中文字幕有码 | 中文字幕天天干| av一区二区三区在线| 日韩精品资源| 7777精品伊人久久久大香线蕉的 | 亚洲精品日韩成人| 免费观看精品视频| a视频免费观看| 欧美一区免费看| 麻豆精品视频在线观看| 国产精品色呦呦| 色婷婷久久一区二区三区麻豆| 亚洲国产成人久久综合| 91精品国产免费久久久久久| 久久99久久精品国产| 欧美日韩在线不卡视频| 中文字幕 自拍| 国产女优在线播放| 国产jizzjizz一区二区| 黄色精品在线看| 亚洲欧洲在线播放| 国产精品人成电影在线观看| 亚洲精品一区二区三区av| 九九热精品国产| 免费视频网站www| 亚洲欧美自偷自拍| 中文乱码免费一区二区| 制服.丝袜.亚洲.中文.综合| 欧美日本啪啪无遮挡网站| 国精产品99永久一区一区| 欧洲av无码放荡人妇网站| 三级影片在线观看| 日韩在线观看视频一区二区三区| 99re视频精品| 欧美电影一区二区| 51视频国产精品一区二区| 亚洲精品一区二| 亚洲成人福利视频| 少妇久久久久久久| 成人视屏免费看| 欧美日韩国产综合视频在线观看| 欧美美女15p| 色一情一区二区三区四区 | 99精品人妻国产毛片| 久久99精品久久久久久久久久久久| 亚洲欧美日韩国产另类专区| 日韩成人黄色av| 91麻豆蜜桃| 国产福利影院在线观看| 日产欧产va高清| 国产一区二区三区黄视频| 日本精品免费观看高清观看| 色综合天天综合网国产成人网 | 色噜噜狠狠一区二区三区狼国成人| 美女精品视频一区| 偷拍精品一区二区三区| 亚洲最大天堂网| 日韩精品中文字幕在线一区| 国产天堂av在线| 久久人人爽人人| 亚洲人妻一区二区| 日韩国产欧美一区| 亚洲色图视频网站| 伊人免费视频二| 亚洲福利视频网站| 日韩福利电影在线| 国产91对白在线观看九色| 欧美日韩久久一区| 国产日韩换脸av一区在线观看| 无码精品国产一区二区三区免费| 精品无码人妻一区二区三区| 国产传媒久久文化传媒| 欧美一区二区视频在线观看2022| 国产精品视频精品| 中文字幕22页| 中文字幕在线一| 亚洲三级在线看| 欧美激情小视频| 久色视频在线播放| 欧美日韩综合一区二区三区| 久久久久久久综合日本| 国产亚洲美女精品久久久| 亚洲成人第一| 美国一级片在线观看| 国产成人亚洲综合a∨婷婷| 精品国产乱码久久| 精品无人区一区二区三区 | 91蝌蚪视频在线| 国产乱人乱偷精品视频| 一区二区三区91| 国外视频精品毛片| 无遮挡又爽又刺激的视频| 欧美一区二区激情视频 | 欧美一区二区福利在线| 99re资源| 无套内谢大学处破女www小说| 视频在线观看一区| 制服丝袜av成人在线看| 99www免费人成精品| 亚洲乱码国产乱码精品精大量| 日韩精品一卡二卡三卡四卡无卡| 91精品婷婷国产综合久久竹菊| 99国产精品久久久久老师| 国产亚洲色婷婷久久99精品91| 日韩精彩视频在线观看| 欧美一区二区三区喷汁尤物| 国产三区二区一区久久| 极品久久久久久久| 26uuu亚洲综合色| 91精品欧美综合在线观看最新 | 亚洲欧美色图小说| 久久久香蕉视频| 亚洲欧洲精品一区二区三区波多野1战4|