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

    
作为一个数据库,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




使用示例

我现在的mongodb数据库有一个集合叫user,我通过js把给每个文档添加一个trueName字段,并赋值等于userName。  再让userName字段 的值 后面加上 110.
mongodb执行js脚本(一)---shell执行_第1张图片
mongodb执行js脚本(一)---shell执行_第2张图片




新建js文件

新建一个fn_add_truename_add110_to_username.js文件
内容为:
  db.user.find().forEach(function(item){
      item.trueName=item.userName;
	  item.userName=item.userName+"110";
	  db.user.save(item);   
  } 
 )


传送js到bin目录

传送到linux的mongodb安装文件夹bin目录下
mongodb执行js脚本(一)---shell执行_第3张图片


执行js文件

在linux系统中  进入mongodb安装目录bin目录
cd  /usr/local/mongodb/mongodb-linux-x86_64-2.6.10/bin/
在bin目录下运行命令
./mongo  127.0.0.1:27017/test  –quiet   fn_add_truename_add110_to_username.js

mongodb执行js脚本(一)---shell执行_第4张图片





也可以进入mongo后 直接把js目录复制粘贴 回车执行:
["字符串1","字符串2"].forEach(function(item){print(item + '\t' + db.resultTxt.count({ "resultDetail.diseaseResult.highDiseaseResultDetails.name" : item }))})







查看结果

mongodb执行js脚本(一)---shell执行_第5张图片


你可能感兴趣的:(mongodb,js,mongodb基础与运用)