ITKeyword,专注技术干货聚合推荐

注册 | 登录

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

q383965374 分享于 2015-06-09

推荐:使用postgreSQL命令行工具在shell脚本中自动执行数据库脚本

在使用postgreSQL时,很多情况下,我们希望编写一个shell脚本,来完成一些诸如创建数据库、创建数据表等等的操作,这个过程可以用psql工具来实现。 但如果用psql

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






新建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目录下


执行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







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







查看结果




     作为一个数据库,MongoDB有一个很大的优势—它使用js管理数据库,所以也能够使用js脚本进行复杂的管理 mongodb 的shell是javascript实现的,如果直接使用js实现相应的功能则显得很直观和简

相关阅读排行


用户评论

游客

相关内容推荐

最新文章

×

×

请激活账号

为了能正常使用评论、编辑功能及以后陆续为用户提供的其他产品,请激活账号。

您的注册邮箱: 修改

重新发送激活邮件 进入我的邮箱

如果您没有收到激活邮件,请注意检查垃圾箱。