有时候我们的字段里的数据为空而去查询就会报错。

比如以下形式:

“cartList”:[]

“cartList”:[{}]

“cartList”:{}

“cartList”:null

在查询的时候加上给可能为空的字段加上$exists。

以下内容抄自,感谢博主https://blog.csdn.net/yaomingyang/article/details/75116142

$exists语法: { field: { $exists: <boolean> } }

1.当boolean为true,$exists匹配包含字段的文档,包括字段值为null的文档。

2.当boolean为false,$exists返回不包含对应字段的文档。

如下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 }

  

最新文章

  1. 深入理解DOM节点类型第六篇——特性节点Attribute
  2. C# WinForm 技巧:COMBOBOX搜索提示
  3. 将库打包到nuget服务器
  4. 动态调用WebService(C#) (非常实用)
  5. WideCharToMultiByte和MultiByteToWideChar函数的用法
  6. 【转】统计模型-n元文法
  7. JQuery ztree 异步加载实践
  8. Python基本概念及零碎知识点
  9. Datawindow.net 子数据窗口出错
  10. American tour(If you have a chance)
  11. 前端知识复习一(css)
  12. CF266D. BerDonalds [图的绝对中心]
  13. Android艺术开发探索第三章————View的事件体系(下)
  14. ReactJS虚拟DOM效应带来的一则副作用探索
  15. 【转】使用keepalived设置虚拟IP示例
  16. 微信小程序计算金额长度异常解决办法
  17. SpringCloud-day06-Ribbon负载均衡
  18. CSS字体样式属性
  19. weblogic的基本概念
  20. flask day01

热门文章

  1. 3.QT计算机实战
  2. Homebrew的安装及使用
  3. &lt;%=%&gt;、&lt;%%&gt;、&lt;%@%&gt;、&lt;%#%&gt;的区别
  4. Jlink如何校验Hex
  5. SpringCloud学习笔记(17)----Spring Cloud Netflix之服务网关Zuul的使用
  6. 路飞学城-Python开发-第二章
  7. BZOJ1567 [JSOI2008]Blue Mary的战役地图(二分+二维hash)
  8. docker系列之一 image和container
  9. STM32为什么必须先配置时钟
  10. idea 包的显示方式