加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Nosql Mongodb之旅(9)—MongoDB高级查询の存储过程

发布时间:2020-12-13 13:46:22 所属栏目:百科 来源:网络整理
导读:下面我们将这个sql 自定义函数转换为MongoDB 的存储过程: [plain]view plaincopy db.system.js.save({_id:"addNumbers",value:function(x,y){returnx+y;}}); 存储过程可以被查看,修改和删除,所以我们用find 来查看一下是否这个存储过程已经被创建上了。 [p

下面我们将这个sql 自定义函数转换为MongoDB 的存储过程:

[plain]view plaincopy
  1. >db.system.js.save({_id:"addNumbers",value:function(x,y){returnx+y;}});

存储过程可以被查看,修改和删除,所以我们用find 来查看一下是否这个存储过程已经被创建上了。

[plain]view plaincopy
  1. >db.system.js.find()
  2. {"_id":"addNumbers","value":functioncf__1__f_(x,y){
  3. returnx+y;
  4. }}
  5. >

这样看起来还不错,下面我看来实际调用一下这个存储过程:

[plain]view plaincopy
  1. >db.eval('addNumbers(3,4.2)');
  2. 7.2
  3. >

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

[plain]view plaincopy
  1. db.eval()是一个比较奇怪的东西,我们可以将存储过程的逻辑直接在里面并同时调用,而无需事先声明存储过程的逻辑。
  2. >db.eval(function(){return3+3;});
  3. 6
  4. >

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



  1. >db.system.js.save({_id:"get_count",value:function(){returndb.c1.count();}});
  2. >db.eval('get_count()')
  3. 2

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读