MongoDB 存储过程

本文深入探讨MongoDB中存储过程的实现方式,即利用system.js集合存放JS方法,并通过eval执行。介绍了存储过程的创建、执行及利弊分析,强调其在减少应用逻辑与DB交互方面的优势,但也指出了不支持sharded collection、性能瓶颈和安全风险等问题。

本文主要介绍mongo存储过程,每个MongoDB的数据库中都有个特殊的集合:system.js,用来存放javascript变量.这些变量可以在任何MongoDB的javascript上下文中调用。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)')

利弊分析

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

一致性,由于不支持sharded collection,如果开始在非shard上这么做,那么后面需要sharding了,没法向后兼容
性能,eval方法会有全局lock,影响性能
安全角度,eval 可能会导致sql 注入问题。同时需要admin用户
综上所述,不建议使用stored procedure.有case需求的可以关注下这个issue
 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值