MongoDB–shell的使用


文章目录

  • MongoDB--shell的使用
  • 一:shell连接到指定机器
  • 1.启动前指定端口
  • 2.启动后指定
  • 二:help
  • 三:使用shell执行脚本
  • 1.不进入shell客户端
  • 2.进入shell客户端使用load()函数
  • 3.创建.mongorc.js文件
  • 3.1 示例
  • 3.2 实际应用场景
  • 4.mongo --eval 运行一段脚本
  • 5.定制shell提示
  • 6.设置EDITOP,编辑复合变量
  • 6.1 在环境变量中配置EDITOR路径
  • 6.2 mongo的shell自启动文件.mongorc.js配置
  • 6.3 使用
  • 7.辅助函数
  • 四:对集合的访问
  • 1.使用getCollection函数
  • 2.通过数组访问子集合


一:shell连接到指定机器

1.启动前指定端口

mongo some-host:30000/myDB
mongoDB shell version:2.4.0
connecting to:some-host:30000/myDB
>

db现在就指向了some-host:30000的myDB数据库

2.启动后指定

使用 --nodb启动就不会连接任何数据库

> mongo --nodb
MongoDB shell version: 2.4.0

启动之后运行new Mongo(hostname)命令就可以连接到想要的数据库

> conn=new Mongo("some-host:30000")
> db=conn.getDB("myDB")

二:help

db.help()查看数据库级别的帮助,db.foo.help()查看集合级别的帮助

还可以直接在shell里面输入函数名,就可以看到函数的具体实现

db.foo.update

三:使用shell执行脚本

1.不进入shell客户端

编写js脚本文件mong.js

sudo vi mongo.js
加上如下内容:
print("I am albert shao in the mongo.js")

编写js脚本文件mongo2.js

sudo vi mongo1.js
加上如下内容:
var a=1;
var b=7;
print("hello:"+a*b)

执行脚本文件

[hadoop@hadoop01 bin]$ mongo --quiet mongo.js
I am albert shao in the mongo.js

[hadoop@hadoop01 bin]$ mongo --quiet mongo2.js
hello:7

2.进入shell客户端使用load()函数

> load("mongo.js")
I am albert shao in the mongo.js
true
> 


> load("mongo2.js")
hello:7
true
>

注意:脚本文件一定要指定具体目录,如果是放在mongoDB的bin下不用指定,其他的都要指定绝对路径

3.创建.mongorc.js文件

3.1 示例

如果某些脚本会被频繁加载,可以将它们添加到.mongorc.js中,在启动shell的时候会自动去加载.mongorc.js

#创建一个.mongorc.js文件
sudo vi .mongorc.js
#添加以下的内容
var compliment = ["like albert","attractive","intellgient"];  
var index = Math.floor(Math.random()*3);  
print("Hello, you're looking particularly " + compliment[index] + "  today!");
#移动到主目录下,windows是移动到admin
mv .mongorc.js ~

每次启动shell的时候会去自动加载.mongorc.js

[hadoop@hadoop01 bin]$ mongo -quiet
Hello, you're looking particularly intellgient  today!
>
3.2 实际应用场景

可以使用这个脚本创建一些自己需要的全局变量,或者是为太长的名字创建一个简短的名字,也可以重写内置的函数。

.mongoorc.js最常见的用途是"禁止"比较危险的shell辅助函数

var no =function(){
print("不要删除数据!!!!");
};
//禁止删除数据库
db.dropDatabase=DB.prototype.dropDatabase = no;
//禁止删除集合
DBCollection.prototype.drop=no;
//禁止删除索引
DBCollection.prototype.dropIndex=no;

加载之后在删除数据,会有以下提示

> show dbs
admin   0.000GB
config  0.000GB
cqsm    0.000GB
local   0.000GB
test    0.000GB
> db.dropDatabase("cqsm")
不要删除数据!!!!
>

如果试图调用这些函数就会的到错误提示,避免自己手误.

可以在启动的时候指定–norc参数,就可以禁止加载.mongorc.js

mongo --norc

4.mongo --eval 运行一段脚本

mongo 127.0.0.1:27017/test --eval "printjson(db.users.findOne())"

5.定制shell提示

将prompt变量设置为一个字符串或者是函数,就可以重写默认的shell提示。

定制提示实现shell提示出输出当前的时间,这样就可以知道最后一个操作完成的时间了。

prompt = function(){
	return (new Date()+">");	
};

还可以显示当前使用的数据库

prompt = function(){
	if(typeof db=='undefined'){
		return '(nodb)>';
	}
	//检查最后的数据库操作
    try{
    	db.runCommand({getLastError:1});
    }
    catch (e) {
    	print(e);
    }
    return db+">";
};

runCommand模糊查询的作用,getLastError可以捕获数据库最后一次错误

重新连接客户端之后:就可以显示当前属于哪个数据库了

test>use cqsm
switched to db cqsm
cqsm>

6.设置EDITOP,编辑复合变量

由于shell不支持跨行编辑,所以可以配置编辑器,当使用edit 命令就会跳转到指定的编辑器,编辑完成在之后保存退出。

6.1 在环境变量中配置EDITOR路径
编辑环境变量配置文件
sudo vi etc profile
在profile中加上自己喜欢的编辑器的路径
export EDITOR=/bin/vi
6.2 mongo的shell自启动文件.mongorc.js配置
加上如下内容:
EDITOR="/bin/vi";
6.3 使用
test>var wap=db.blog.findOne()
test>edit wap
{
        "_id" : ObjectId("5dd65a99a8831f1e3fedb52a"),
        "title" : "aaa",
        "name" : "zs"
}
修改完保存退出,再查看

test>wap
{
        "_id" : ObjectId("5dd65a99a8831f1e3fedb52a"),
        "title" : "aaa",
        "name" : "zs",
        "sex" : "n"
}

7.辅助函数

在脚本中可以直接访问db变量以及其他的一些全局变量,但是有一些辅助函数不可以在js文件中使用,它们有对应的js函数

辅助函数

等价js函数

use foo

db.getSisterDB(“foo”)

show dbs

db.getMongo().getDBs()

show collections

db.getCollectionNames()

可以使用脚本将变量注入到shell,初始化一些函数,加载之后直接在shell中调用。如下定义的函数可以连接到一个指定的本地数据库,并且将db指向这个连接

在linux主目录~下建立一个shell脚本文件
sudo vi defineConnectTo.js
var connecttTo = function(port,dbname) {
	if(!port){
		port=27017;
	}
	if(!dbname){
		dbname="test";
	}
	db=connect("localhost:"+port+"/"+dbname);
};

在shell中加载这个脚本文件

test>typeof connecttTo
undefined
test>load('defineConnectTo.js')
true
test>typeof connecttTo
function
test>connecttTo
function (port,dbname) {
        if(!port){
                port=27017;
        }
        if(!dbname){
                dbname="test";
        }
        db=connect("localhost:"+port+"/"+dbname);
}
test>

四:对集合的访问

1.使用getCollection函数

test>db.getCollection("blog")
test.blog

如果集合中包含了无效的js属性名称,也可以使用这个函数。

注意:JS属性名称只能包含字母,数字,$,和_ ,而且不能使用数组开头

2.通过数组访问子集合

通过变量和数组访问子集合

var collection = ["post","comments","authrs"];
for(var i in collections){
	print(db.blog[collections[i]]);
}

而不用这样:

print(db.blog.post);
print(db.blog.comments);
print(db.blog.authrs);

注意:不能使用db.blog.i,只能使用db.blog[i]