博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mongo 存储过程
阅读量:5087 次
发布时间:2019-06-13

本文共 1004 字,大约阅读时间需要 3 分钟。

摘要

本文主要介绍mongo存储过程,mongo 存储过程其实就是JS方法,然后通过eval 方法来执行,但是这个方法在3.0 depreate了,也就是在未来的版本,这个功能可能不提供了。从目前的jira的issue来看,mongo官方还没有打算提供了eval的替代。

介绍

mongo 存储过程其实就是在database 端存储js 方法

db.system.js.save({    _id:"add",     value:function(x, y){        return x + y;      }});

然后通过db.system.js.find() 查看是否被成功加入

通过eval方法来执行存储过程

db.eval('add(2,3)')

问题

上面这位网友提出来的问题是比较典型的,很容易遇到的

WARNING: db.eval is deprecatedError: {"ok" : 0,"errmsg" : "ReferenceError: z_add is not defined :\n_funcs1@:1:24\n","code" : 139} :

这个问题产生的原因是因为存入了没有带id的js方法,可以通过db.system.js.find()来查看。使用db.system.js.remove()掉不带id的方法即可。

sharded collection

eval()方法不支持在sharded collection,可能原因在于

  1. eval()方法在sharded 架构之前出来
  2. 在sharded cluster 架构中,将逻辑放在DB意义不大,同样需要在各个shard上进行查询

利弊分析

将应用逻辑放在DB端,可以集成query,update,减少application 到db 的连接请求

  1. 一致性,由于不支持sharded collection,如果开始在非shard上这么做,那么后面需要sharding了,没法向后兼容
  2. 性能,eval方法会有全局lock,影响性能
  3. 安全角度,eval 可能会导致sql 注入问题。同时需要admin用户

综上所述,不建议使用stored procedure.有case需求的可以关注下这个issue

参考

转载于:https://www.cnblogs.com/stoneFang/p/6715286.html

你可能感兴趣的文章
iOS Cell异步图片加载优化,缓存机制详解
查看>>
第二章 基本数据结构
查看>>
(转)Unity3D移动平台动态读取外部文件全解析
查看>>
回顾与陈景润讨论歌德巴哈猜想的情景
查看>>
移动端 竖屏 (转)
查看>>
css text-align
查看>>
c语言章节4
查看>>
VC(VISUAL_C++)虚拟键VK值列表
查看>>
《风笛》-林白
查看>>
Android 网络请求框架Retrofit
查看>>
GeoServer手动发布本地Shapefile地图
查看>>
KMP之我见
查看>>
BZOJ1119[POI2009]SLO && BZOJ1697[Usaco2007 Feb]Cow Sorting牛排序
查看>>
<a>标签中的href伪协议 ...
查看>>
java初始化过程中成员变量
查看>>
20145322 《信息安全系统设计基础》第十周学习总结
查看>>
babel常识备忘
查看>>
js中的事件代理(委托)
查看>>
Django组件——分页器和中间件
查看>>
scala 14 trait
查看>>