~/.mongorc.js文件描述如下:
#mongorc.js
===============
我的 mongorc.js 文件.
提供:
- `pretty()` 默认使用pretty()帮助方法查询
- `ugly()` 帮助方法
- prompt 显示与服务端类型相关的信息
## Pretty
mongo shell 有一个帮助函数叫做 `pretty()` 用于美化结果集。 使用这个 mongorc.js 文件默认启用pretty行为。
> db.marioGames.find()
{
"_id" : ObjectId("507333d49c25fa3b6e62174d"),
"name" : "Super Mario Bros",
"super" : true,
"release" : ISODate("1985-09-13T07:00:00Z")
}
{
"_id" : ObjectId("5073347b9c25fa3b6e62174e"),
"name" : "Super Mario Bros 2",
"super" : true,
"release" : ISODate("1988-10-09T07:00:00Z")
}
{
"_id" : ObjectId("5073348f9c25fa3b6e62174f"),
"name" : "Super Mario Bros 3",
"super" : true,
"release" : ISODate("1990-02-09T08:00:00Z")
}
## Ugly
现在我们默认得到pretty的结果集合,我们偶尔会需要之前的行为(打印文档到单行)。
通过使用 `ugly()` 帮助方法。方法:
> db.marioGames({ super: true }).ugly();
{ "_id" : ObjectId("507333d49c25fa3b6e62174d"), "name" : "Super Mario Bros", "super" : true, "release" : ISODate("1985-09-13T07:00:00Z") }
{ "_id" : ObjectId("5073347b9c25fa3b6e62174e"), "name" : "Super Mario Bros 2", "super" : true, "release" : ISODate("1988-10-09T07:00:00Z") }
{ "_id" : ObjectId("5073348f9c25fa3b6e62174f"), "name" : "Super Mario Bros 3", "super" : true, "release" : ISODate("1990-02-09T08:00:00Z") }
## Prompt
默认的prompt现在显示与连接的服务端相关的信息。
####replSet
```
replSetName:ServerState|database>
```
####mongos
```
mongos|host:port|database>
```
####mongod
```
mongod|host:port|database>
```
## Installation
git clone git@github.com:aheckmann/mongorc.js.git
cd mongorc.js
make install
它拷贝 .mongorc.js 文件到你的HOME路径主目录。
如果另一个 .mongorc.js 文件已经存在,它会被重命名为 .mongorc.js.old
## Uninstall
cd mongorc.js
make uninstall
如果 ~/.mongorc.js.old 存在,它将重命名为 ~/.mongorc.js
## Licence
MIT
~/.mongorc.js文件内容如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
;(
function
() {
/**
* Make all queries pretty print by default.
*/
DBQuery.prototype._prettyShell =
true
/**
* Allow opting into the default ugly print mode.
*/
DBQuery.prototype.ugly =
function
() {
this
._prettyShell =
false
;
return
this
}
/**
* Override the default prompt to display info related
* to type of server we connected to.
*
* @return {String}
*/
prompt =
function
() {
var
res = rs.status();
if
(!res || res.errmsg) {
// not in a replica set
var
status = db.serverStatus();
return
status.process +
"|"
+ status.host +
"|"
+ db +
"> "
;
}
return
replsetPrompt();
}
/**
* Creates a prompt string for replSets
*
* @return {String}
*/
function
replsetPrompt () {
var
status;
var
admin = db.getSiblingDB(
"admin"
);
var
info = admin.runCommand({ replSetGetStatus: 1, forShell: 1});
if
(info.ok) {
var
state =
""
;
// do we need this?
info.members.some(
function
(member) {
if
(member.self) {
state = member.stateStr;
return
true
;
}
});
status = info.set +
":"
+ (state || info.myState);
}
else
if
(info.info && info.info.length < 20) {
// < 20 seems like a hack ??
status = info.info;
}
return
status +
"|"
+ db +
"> "
}
})();
|
参见:https://github.com/aheckmann/mongorc.js
本文转自UltraSQL51CTO博客,原文链接: http://blog.51cto.com/ultrasql/1707359,如需转载请自行联系原作者