MongoDB高级查询 互动版

在线工具推荐: Three.js AI纹理开发包 - YOLO合成数据生成器 - GLTF/GLB在线编辑 - 3D模型格式在线转换 - 可编程3D场景编辑器

eval调用存储过程

前面看起来还不错,下面使用eval()实际调用一下这个存储过程:

> db.eval('addNumbers(3, 4.2)');
7.2

这样的操作方法简直太简单了,也许这就是MongoDB 的魅力所在。

db.eval()是一个比较奇怪的东西,我们可以将存储过程的逻辑直接在里面并同时调用,而无 需事先声明存储过程的逻辑。

```> db.eval( function() { return 3+3; } ); 6 >


从上面可以看出,MongoDB 的存储过程可以方便的完成算术运算,但其它数据库产品在存
储过程中可以处理数据库内部的一些事情,例如取出某张表的数据量等等操作,这些
MongoDB 能做到吗?答案是肯定的,MongoDB 可以轻而易举的做到,看下面的实例吧:

db.system.js.save({_id:"get_count", value:function(){ return db.c1.count(); }}); db.eval('get_count()') 2 ```

可以看到存储过程可以很轻松的在存储过程中操作表