解決mongodb TypeError: Cannot read property 'XXX' of null 問題

有時候咱們的字段裏的數據爲空而去查詢就會報錯。javascript

好比如下形式:java

「cartList」:[]spa

「cartList」:[{}].net

「cartList」:{}code

「cartList」:nullblog

在查詢的時候加上給可能爲空的字段加上$exists。ip

如下內容抄自,感謝博主https://blog.csdn.net/yaomingyang/article/details/75116142文檔

 

$exists語法: field: $exists: <boolean> }

1.當boolean爲true,$exists匹配包含字段的文檔,包括字段值爲null的文檔。get

2.當boolean爲false,$exists返回不包含對應字段的文檔。it

以下records集合:
{ a: 5, b: 5, c: null }
{ a: 3, b: null, c: 8 }
{ a: null, b: 3, c: 9 }
{ a: 1, b: 2, c: 3 }
{ a: 2, c: 5 }
{ a: 3, b: 2 }
{ a: 4 }
{ b: 2, c: 4 }
{ b: 2 }{ c: 6 }
db.records.find( { a: { $exists: true } } )
查詢結果是:
{ a: 5, b: 5, c: null }
{ a: 3, b: null, c: 8 }
{ a: null, b: 3, c: 9 }
{ a: 1, b: 2, c: 3 }
{ a: 2, c: 5 }
{ a: 3, b: 2 }
{ a: 4 }

db.records.find( { b: { $exists: false } } )

  查詢結果以下:

{ a: 2, c: 5 }
{ a: 4 }
{ c: 6 }
相關文章
相關標籤/搜索