概念
数据库命令(database command)是一种非常特殊类型的查询。文档的创建、更新、删除及查询都属于数据库命令的范畴,它还包含管理性的任务(比如关闭服务器和克隆数据库)、统计数据及执行聚合操作等。
runCommand函数
通常,只使用shell提供的函数就可以了,但是了解它们底层的命令是很有帮助的。尤其是当使用就版本shell连接到新版本的数据库上时,这个shell可能不支持新版数据库的一些命令,这时就不得不使用“数据库命令”的runCommand函数。使用方式:db.runCommand({“命令名称”:值})
数据库命令工作原理
数据库命令总会返回一个包含“ok”键的文档。如果“ok”的值是1,说明命令执行成功。反之失败。如果“ok”值为0,那么命令的返回文档就会有一个额外的键-“errmsg”。它是一个字符串类型用于描述失败的原因。
上面开头说道“数据库命令”是一种特殊类型的查询,是因为MongoDB服务器接收到一个runCommand发过来的命令时,会把这个请求处理成$cmd集合的一个查询操作。例如,shel发送一个db.runCommand(“drop”,”test”)命令(删除一个test集合),服务器会转换为 db.$cmd.findOne({“drop”:”test”})
当一些命令需要有管理员权限的时候,而且要在admin(MongoDB系统自带的数据库)数据库上才能执行时,就不能用runCommand函数了,改用adminCommand函数就可以了。否则会得到一个“access denied”的错误。