为mongo Shell编写脚本
在本页面
[success] Note
下面的文档是MongoDB服务器下载.中包含的
mongo
shell。有关新的MongoDB Shell ,mongosh的信息,请参考mongosh文档。要了解这两种shell的区别,请参阅Comparison of the mongo Shell and mongosh.
您可以为mongo
shell编写JavaScript 的脚本,来处理MongoDB中的数据或执行管理操作。 本章节介绍了通过mongo
shell编写的JavaScript
的方法 来访问 Mongodb的方式。
打开新连接
在mongo
shell或JavaScript文件中,您可以使用Mongo()
构造函数实例化数据库连接:
请考虑以下示例,该示例实例化与在默认端口上的localhost上运行的MongoDB实例的新连接,并使getDB()
方法将全局db变量设置为myDatabase:
如果连接到已经开启了访问控制的MongoDB实例,则可以使用db.auth()
方法进行身份验证。
此外,您可以使用connect()
方法连接到MongoDB实例。 以下示例使用非默认端口27020连接到在localhost上运行的MongoDB实例,并设置全局db变量:
另可参考: mongo Shell Methods
交互式mongo与脚本mongo的区别
[success] Note
从4.2版开始,
mongo
shell提供了isInteractive()
方法,该方法返回一个布尔值,该值指示mongo
shell是在交互模式还是脚本模式下运行。
为mongo shell编写脚本时,请考虑以下事项:
要设置db全局变量,请使用
getDB()
方法或onnect()
方法。您可以将数据库引用分配给db以外的其他变量。mongo
shell中的写操作默认情况下使用{ w: 1 }的写入策略。 如果执行批量操作,请使用Bulk()
方法。 有关更多信息,请参见:Write Method Acknowledgements)。您不能在JavaScript文件中使用任何shell帮助程序(例如,使用
<dbname>
,show dbs等),因为它们不是有效的JavaScript。 下表将最常见的mongo shell助手映射到其JavaScript等效项:
show dbs, show databases
db.adminCommand('listDatabases')
use <db>
db = db.getSiblingDB('<db>
')
show collections
db.getCollectionNames()
show users
db.getUsers()
show roles
db.getRoles({showBuiltinRoles: true})
show log<logname>
db.adminCommand({ 'getLog' : '<logname>
' })
show logs
db.adminCommand({ 'getLog' : '*' })
it
cursor = db.collection.find() if ( cursor.hasNext() ){ cursor.next(); }
在交互模式下, mongo
打印操作结果,包括所有游标的内容。 在脚本中,使用JavaScript **print()函数或 mongo
特定的printjson()**函数,该函数返回格式化的JSON。
例子:
要在mongo shell脚本中打印结果游标中的所有项目,请使用以下惯用法:
脚本编写
在系统提示下,使用mongo
评估JavaScript。
--eval选项
使用--eval选项 让Mongo来执行一个JavaScript片段,如下所示:
这将使用连接到在本地主机接口上的端口27017上运行的mongod
或mongos
实例的mongo
shell返回db.getCollectionNames()
的输出。
执行一个JavaScript文件
您可以在mongo shell中指定.js文件,然后mongo将直接执行JavaScript。 考虑以下示例:
此操作在mongo shell中执行myjsfile.js
脚本,该脚本连接到可通过端口27017上的localhost接口访问的mongod实例上的测试数据库。或者,您可以使用Mongo()
构造函数在javascript文件中指定mongodb连接参数。
有关更多信息,请参见:打开新连接 。
您可以使用load()
函数从mongo shell中执行.js文件,如下所示:
此函数加载并执行myjstest.js文件。 load()方法接受相对路径和绝对路径。 如果mongo shell的当前工作目录为/ data / db,而myjstest.js位于**/ data / db / scripts**目录中,则mongo shell中的以下调用将是等效的:
[success] Note
load()函数没有搜索路径。 如果所需的脚本不在当前工作目录或完整的指定路径中,则
mongo
将无法访问该文件。
译者:王恒
校对:杨帅
最后更新于