MongoDB 存储过程
2022/1/19 19:21:13
本文主要是介绍MongoDB 存储过程,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
MongoDB 存储过程
本文主要介绍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
这篇关于MongoDB 存储过程的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-04-01got an unexpected keyword argument
- 2024-03-30维多利亚的秘密 golang入坑系统
- 2024-03-29mongodb sort by date
- 2024-03-29go swagger
- 2024-03-25mongodb cdc
- 2024-03-25how to use go in vscode
- 2024-03-22mongooseserverselectionerror: connect econnrefused ::1:27017
- 2024-03-21pymongo insert_many
- 2024-03-18projection mongodb
- 2024-03-14clickhouse-go