mongodb执行js脚本(一)---shell执行

和自甴很熟 提交于 2020-02-28 21:52:11

mongodb执行js脚本(一)---shell执行

2015年06月09日 10:58:36 张小凡vip 阅读数 21310更多

所属专栏: mongodb基础与运用

 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/q383965374/article/details/46414115

    

作为一个数据库,MongoDB有一个很大的优势—它使用js管理数据库,所以也能够使用js脚本进行复杂的管理

 

mongodb 的shell是javascript实现的,如果直接使用js实现相应的功能则显得很直观和简便。

 

比如我们对一些数据进行 统计计算,除了使用mapreduce之外,直接使用js也是很好的选择。

 

还有一些批处理,数据同步都可以使用js

 

使用js脚本进行交互的优点与缺点

(1)无需任何驱动或语言支持;

(2)方便cron或管理员定时任务;

(3)注意点:任然是数据格式的问题;

 

 

js脚本一般会用来执行以下任务

(1)备份;

(2)调度map-reduce命令;

(3)离线报告,离线任务;

(4)管理员定时任务;

 

 

如何运行一个js脚本

./mongo 127.0.0.1:3003/test –quiet test.js

说明:

(1)./mongo

mongo客户端-_-;

(2)127.0.0.1:3003/test

服务器的ip,port,以及需要连接的数据库;

(3)–quiet

省略一些头信息

(4)test.js

待运行的脚本,内容是:

db.test.find().forEach(printjson);

 

 

也可以使用–eval参数

./mongo 127.0.0.1:3003/test  –eval “db.test.find().forEach(printjson);”

–eval参数后面直接跟一个js语句。

 

 

其他的一些说明

(1)通常使用两种方法打印获取到的结果:

print() => 普通js

printjson() => 格式化json打印,打印出来的格式会漂亮许多

(2)迭代器(iterator command)在脚本操作中将失效

(3)如何知道insert、delete、update等操作是否成功呢,请使用:

db.getLastErrorObj()

或者

db.getLastError()

(4)js shell的相关介绍见:

https://developer.mozilla.org/En/SpiderMonkey/Introduction_to_the_JavaScript_shell

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!