mongo基础之 shell 学习(2)

linux连接默认端口上的本地MongoDB实例

直接输入mongo,这样会默认链接到本地主机上端口27017上运行的mongoDB实例

mongo

linux连接非默认端口上的本地MongoDB实例

要显式指定端口,请包括–port命令行选项。

$ mongo --port 28015

linux连接远程主机上的MongoDB实例

三种方法:

mongo mongodb://127.0.0.1:27017

mongo --host 127.0.0.1:27017

mongo --host 127.0.0.1 --port 27017 连接MongoDB服务器

mongo --host 127.0.0.1:27017  -u root -p 123456 默认连接admin数据库

把上面的127.0.0.1换成你的远程ip地址,27017换成端口就可以了

MongoDB授权

use dbname  切换到用户有权限的数据库。

 db.auth("user","password");   进行授权

然后就可以操作了。

要显示正在使用的数据库

> db
test  --test 是默认数据库

备注:shell是一个独立的mongoDB客户端,开启的时候,shell会连到mongoDB服务器的test数据库,并将这个数据库连接赋值到全局变量db。这个变量是通过shell访问MongoDB的主要入口点。
备注:因为这是一个JaveScript Shell,所以键入一个变量会将变量的值转换为字符串并打印出来。
备注:可以通过db变量来访问其中的集合

当前用户可用的数据库

> show dbs;
admin   0.000GB
config  0.000GB
local   0.000GB

备注:

  •  admin:从权限的角度来看,这是root数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行
  •  local:这个数据永久不会被复制,可以用来存储限于本地单台服务器的任意集合
  •  config:当mongoDB用于分片设置时,config数据库在内部使用,用于保存分片的相关信息

切换数据库

> use  local
switched to db local

 

切换到不存在的数据库

> use myNewDatabase
switched to db myNewDatabase
> db.myCollection.insertOne({x:1});
{
    "acknowledged" : true,
    "insertedId" : ObjectId("5c8e03a17c4706ac88a6153f")
}
> show dbs
admin          0.000GB
config         0.000GB
local          0.000GB
myNewDatabase  0.000GB

 

db.myCollection.insertOne时:会创建myNewDatabase数据库并插入一个数据
db.mycollection.insertone()是mongo shell中可用的方法之一。

  •  db是指当前数据库。
  •  myCollection是集合的名称。

如果mongo shell不接受集合的名称,则可以使用可选的db.getCollection()语法。例如,如果集合名称包含空格或连字符、以数字开头或与内置函数冲突:

db.getCollection("3 test").find()
db.getCollection("3-test").find()
db.getCollection("stats").find()

mongo shell提示的每行代码点限制为4095个。如果输入的行的代码点超过4095个,shell将截断它。

设置打印结果的格式

db.collection.find()方法将光标返回到结果中;.pretty()方法可以格式化打印结构

> db.myCollection.find().pretty()
{ "_id" : ObjectId("5c8e03a17c4706ac88a6153f"), "x" : 1 }

 

mongodb shell多行操作

mongoDB shell会检测输入的JaveScript语句是否写完,如果没有写完还可以在写一行接着写

> x = 10
10
> if(x>0){
... print(x)
... }
10

  • shell支持很多快捷键,比如Tab

退出shell

要退出shell,请键入quit()或使用快捷方式。

自定义提示

方法:在mongo shell中设置变量prompt

例子1:
(1) 当前会话中直接输入

cmdCount = 1;
prompt = function() {
    return (cmdCount++) + "> ";
}
(2) 效果

例子2:
(1) 当前会话中直接输入

host = db.serverStatus().host;

prompt = function() {
             return db+"@"+host+"$ ";
}

(2) 效果
在这里插入图片描述

例子3:
(1) 当前会话中直接输入

prompt = function() {
           return "Uptime:"+db.serverStatus().uptime+" Documents:"+db.stats().objects+" > ";
}

(2) 效果
在这里插入图片描述
备注:只在当前会话有效

在Mongo Shell¶中使用外部编辑器

在启动mongo shell之前,可以通过设置editor环境变量在mongo shell中使用自己的编辑器

export EDITOR=vim
在mongo shell中,可以通过键入edit或edit使用指定的编辑器进行编辑,如下例所示:

  1. 定义函数myFunction

function myFunction () { }

    2   使用外部编辑器编辑函数

edit myFunction

该命令应打开VIM编辑会话。完成编辑后,保存并退出VIM编辑会话。

3 在mongoDB Shell中,输入函数名查看函数定义

> myFunction
function myFunction() {
    print("This was edited");
}

更改Mongo Shell批量大小

db.collection.find()方法是从集合中检索文档的javascript方法。db.collection.find()方法将光标返回到结果中;但是,在mongo shell中,如果返回的光标没有使用var关键字分配给变量,那么光标将自动重复最多20次,以打印到与查询匹配的前20个文档。mongo shell将提示键入它,以便再重复20次。

可以设置dbquery.shellbatchsize属性,将文档数从默认值20更改为10,如下例所示:

DBQuery.shellBatchSize = 10;

命令行帮助

在linux shell命令行中,输入

$ mongo --help

shell帮助

在mongo shell中,输入

> help

数据库帮助

在mongo shell中

  • 查看可用的数据库信息

> show dbs
> show databases;
 

  • 查看db对象可以使用的方法

> db.help()
 

  • 查看方法的实现:不带()的db.< method name>,比如想要查看 db.updateUser()的实现:

> db.updateUser

Collection帮助

*要查看当前数据库中的集合列表

> show collections
 

具体:show collections

  • 查看集合对象(例如db.)上可用方法的帮助,请使用db..help()方法

db.collection.help()
 

 <collection>是集合的名称,集合可以存在也可以不存在。

  • 查看集合方法的实现,不带()的 db.< collection>.< method>,比如想要看db.collection.save()方法的实现

> db.collection.save
 

Cursor 帮助

使用mongo shell中的find()方法执行读取操作时,可以使用各种Cursor 方法修改find()行为,并使用各种javascript方法处理find()方法返回的Cursor 。

  • 要列出可用的修饰符和Cursor 处理方法,请使用db.collection.find().help()命令:

db.collection.find().help()

< collection>是集合的名称,集合可以存在也可以不存在。

  • 查看Cursor 方法的实现,不带()的 db.< collection>.find().< method>,比如查看db.collection.find().toArray()的实现

db.collection.find().toArray

一些有用的处理Cursor 的方法

  • hasNext() 检测Cursor 有没有文档还没有显示
  • Next()返回下一个文档并将Cursor 位置向前推进一个
  • foreach(< function>)迭代整个光标,并将应用于光标返回的每个文档。需要一个单独的参数,该参数对应于每个迭代中的文档。

有关迭代光标和从光标检索文档的示例,请参见光标处理。有关所有可用的光标方法,请参见光标

var xx=db.getCollection('variable').find({}).limit(2)
while(xx.hasNext()){
    var one=xx.next()
    printjson(one)
}

mongo shell的脚本(在Mongo shell 中连接另外的MongoDB)

操作数据 或 执行管理操作。

javascript连接服务器

从mongo shell或javascript文件,可以使用mongo()构造函数实例化数据库连接:

new Mongo()

new Mongo(<host>)

new Mongo(<host:port>)

考虑下面的示例,该示例实例化到默认端口上本地主机上运行的mongodb实例的新连接,并使用getdb()选择数据库mydatabase为当前数据库:

conn = new Mongo();

db = conn.getDB("myDatabase");

如果连接到强制访问控制的MongoDB实例,则可以使用db.auth()方法进行身份验证。

此外,还可以使用connect()方法连接MongoDB实例。以下示例连接到使用非默认端口27018在本地主机上运行的MongoDB实例,并设置全局DB变量:

> db=connect("localhost:27018")

connecting to: localhost:27018

Implicit session: session { "id" : UUID("4fb851d6-fb74-472f-abb5-68ef675556cf") }

MongoDB server version: 4.0.6

test

> db=connect("localhost:27018/myDatabase")

connecting to: mongodb://localhost:27018/myDatabase

Implicit session: session { "id" : UUID("bb409c38-6ff6-40c9-90b3-bd7bcdaabb60") }

MongoDB server version: 4.0.6

myDatabase

更多请参考:mongo Shell Methods

基于MongoDB支持的javascript实现远程连接

当你已经连接到一个远程的MongoDB数据库服务器(例如,通过mongo连接到192.168.0.184),现在想要在这个会话中连接另一个远程的数据库服务器(192.168.0.197),可以执行如下命令:

上述通过MongoDB提供的JavaScript脚本,实现对另一个远程数据库服务器进行连接,操作指定数据库fashy的orderInfo集合。

启动了安全认证模式,可以在获取数据库的时候添加上认证。

交互式mongo (Linux连接MongoDB得到的MongoDB shell)和  js脚本中的MongoDB操作的区别

为Mongo Shell编写脚本时,请考虑以下内容:

  • 设置db全局变量,请使用getdb()方法或connect()方法。可以将数据库引用分配给db以外的变量。
  • 默认在mongo Shell中写操作是{w:1}的,如果想批量操作,请使用Bulk()。具体请参考 Write Method Acknowledgements
  • 不能在javascript文件中使用任何shell帮助程序(例如,use、show dbs等),因为它们不是有效的javascript。
    下表将最常见的MongoShell帮助程序映射到它们的javascript等价物。

Shell Helpers

JavaScript Equivalents

show dbs, show databases

db.adminCommand(‘listDatabases’)

use

db = db.getSiblingDB(’’)

show collections

db.getCollectionNames()

show users

db.getUsers()

show roles

db.getRoles({showBuiltinRoles: true})

show log

db.adminCommand({ ‘getLog’ : ‘’ })

show logs

db.adminCommand({ ‘getLog’ : ‘*’ })

it

cursor = db.collection.find() if ( cursor.hasNext() ){ cursor.next(); }

  • 在交互模式下,mongo打印操作结果,包括所有光标的内容。在脚本中,要么使用javascript print()函数,要么使用mongo特有的print json()函数,该函数返回格式化的json。
    比如,要在mongo shell脚本中打印结果光标中的所有项,请使用以下习惯用法:

 cursor = db.collection.find();

while ( cursor.hasNext() ) {

   printjson( cursor.next() );

}

脚本编写

在linux系统提示下,使用mongo eval

 – eval option

使用–eval选项mongo向shell传递一个javascript片段,如下所示:

$ mongo test --eval "printjson(db.getCollectionNames())"

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

执行JaveScript脚本

  • 方法1:linux shell命令行

$ mongo localhost:27017/test myjsfile.js

此操作在mongo shell中执行myjsfile.js脚本,该脚本连接到可通过端口27017上的localhost接口访问的mongod实例上的测试数据库。

myjsfile.js内容:

crditidlist=db.getCollection('coll').find({}).hint({"xx":1}).toArray();
var idlist=[];
crditidlist.forEach(function(item){ idlist.push(item.xx);  });

db1=db.getSiblingDB("db1");

db1.auth("user","pass");

rs=db1.getCollection("yy").find({"id":{$in:idlist}});
while(rs.hasNext()) {
     printjson(rs.next());
    print(",");
 }

  • 方法2:mongodb shell命令行

> load("myjstest.js")

方法接受相对路径和绝对路径。如果mongo shell的当前工作目录是/data/db,而myjstest.js位于/data/db/scripts目录中,那么mongo shell中的以下调用将是等效的:

> load("scripts/myjstest.js")

> load("/data/db/scripts/myjstest.js")

shell 数据类型

日期

mongo shell提供各种各样的方法来返回date,包括string类型和Date 对象

  • Date()方法以字符串的格式返回当前日期时间    这是一个北京时间字符串Thu Aug 19 2021 18:51:19 GMT+0800 (CST)
  • new Date() 构造函数使用 ISODate() 装饰器返回一个Date对象   比如ISODate("2021-08-19T10:49:44.313Z")  这是一个UTC时间 
  • ISODate()构造函数使用 ISODate() 装饰器返回一个Date对象     比如ISODate("2021-08-19T10:49:44.313Z") 这是一个UTC时间 

mongoDB内部,日期对象存储为带符号的64位整数,表示自197011日以来的毫秒数。

并非所有的数据库操作和驱动程序都支持完整的64位范围。您可以安全地使用包含09999年的日期。

以字符串格式返回日期

Date方法返回字符串格式的日期

> var myDateString = Date();

> myDateString

Mon Mar 18 2019 14:39:56 GMT+0800 (CST)

> typeof myDateString

string

Date格式返回日志

> var myDate = new Date();

> var myDateInitUsingISODateWrapper = ISODate();

> var myNewDateInitUsingISODateWrapper = new ISODate();

> myDate

ISODate("2019-03-18T06:42:25.682Z")

> myDateInitUsingISODateWrapper

ISODate("2019-03-18T06:42:26.888Z")

> myNewDateInitUsingISODateWrapper

ISODate("2019-03-18T06:42:58.503Z")

> myDate instanceof Date

true

> myDateInitUsingISODateWrapper instanceof Date

true

> typeof myNewDateInitUsingISODateWrapper

object

> myNewDateInitUsingISODateWrapper instanceof Date

true

ObjectId

mongoDB Shell提供了 ObjectId() 包装类,如果要想生成一个新的ObjectId

> new ObjectId

ObjectId("5c8f4008ba43cf660ec8633e")

具体:ObjectId

NumberLong

mongo shell默认将所有数字视为浮点值。mongo shell提供了numberlong()包装器来处理64位整数。
numberlong()包装器接收一个字符串参数:

> NumberLong("2090845886852")

具体例子:

> db.collection.insertOne( { _id: 10, calc: NumberLong("2090845886852") } )

> db.collection.updateOne( { _id: 10 },

... { $set:  { calc: NumberLong("2555555000000") } } )

> db.collection.updateOne( { _id: 10 },

...   { $inc: { calc: NumberLong(5) } } )

> db.collection.findOne({_id:10})

{ "_id" : 10, "calc" : NumberLong("2555555000005") }

  • 如果使用$inc将包含numberlong对象的字段的值增加一个浮点值,则数据类型将更改为浮点值,如下例所示:

> db.collection.updateOne( { _id: 10 },

... { $inc: { calc: 5 } } )

{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }

> db.collection.findOne( { _id: 10 } )

{ "_id" : 10, "calc" : 2555555000010 }

NumberInt

mongo shell默认将所有数字视为浮点值。mongo shell提供了numberint()构造函数来显式指定32位整数。

NumberDecimal

New in version 3.4.

mongo shell默认将所有数字视为64位双精度浮点值。mongo shell提供了numberdecimal()构造函数来显式指定基于128位十进制的浮点值,十分精确。此功能适用于处理货币数据(如财务、税务和科学计算)的应用程序。

numberdecimal()接收一个字符串参数[推荐];以及小数参数,但是不建议这么做,因为这可能丢失精度

> NumberDecimal("1000.55")

NumberDecimal("1000.55")

> NumberDecimal(1000.55)

NumberDecimal("1000.55000000000")

> NumberDecimal(9999999.4999999999)

NumberDecimal("9999999.50000000")

备注:请具体看mongoDB 驱动是否支持这个功能

比较和排序

> db.numbers.insert({ "_id" : 1, "val" : NumberDecimal( "9.99" ), "description" : "Decimal" })

> db.numbers.insert({ "_id" : 2, "val" : 9.99, "description" : "Double" })

> db.numbers.insert({ "_id" : 3, "val" : 10, "description" : "Double" })

> db.numbers.insert({ "_id" : 4, "val" : NumberLong(10), "description" : "Long" })

> db.numbers.insert({ "_id" : 5, "val" : NumberDecimal( "10.0" ), "description" : "Decimal" })

查看是否是十进制类型


使用字符串别名为“decimal”的$type运算符或十进制类型的数字代码19

> db.inventory.find( { price: { $type: "decimal" } } )

查看字段类型

  • instanceof :是不是
  • typeof:是什么

mydoc._id instanceof ObjectId

typeof mydoc._id

linux下mongo 命令选项介绍:

下表显示了Mongo的一些常见选项:

Option

描述

–help / -h

返回有关Mongo选项和使用的信息

–nodb

不连接任何数据库的打开一个新连接

–shell

启用shell接口。如果调用mongo命令并指定一个javascript文件作为参数,或者使用–eval在命令行上指定javascript,则–shell选项在文件执行完毕后为用户提供shell提示。具体请参考执行JaveScript脚本

mongo交互式命令行帮助

命令

描述

help

显示帮助

db.help()

列出db对象上的常用方法。

db.< collection>.help()

显示collection方法的帮助,collection可以存在也可以不存在

show dbs / show databases

显示可用的数据库,类似命令listDatabases

use < db>

切换数据库

show collections

显示当前数据库中可用对象

show users

打印当前数据库的用户列表

show roles

打印当前数据库的所有角色(用户定义的和内置的)列表

show profile

打印最近5次操作,耗时1毫秒或更长时间。具体请参考profile

load()

执行JaveScript脚本,具体请参考为Mongo Shell编写脚本

交互式命令行常用操作:

在mongo shell中,db是引用当前数据库的变量。变量将自动设置为默认数据库测试,或者在使用切换当前数据库时设置。

api

描述

db.auth()

如果在安全模式下运行,则对用户进行身份验证

coll = db.< collection>

coll = db.myCollection; – coll.find();

db.collection.find()

查找集合或视图中的文档,并将光标返回到所选文档,参考

db.collection.insertOne()

插入一个新的对象到集合中

db.collection.insertMany()

插入多个新对象到集合中

db.collection.updateOne()

更新集合中一个已经存在的对象

db.collection.updateMany()

更新集合种多个已经存在的对象

db.collection.save()

插入新文档或更新集合中的现有文档

db.collection.deleteOne()

删除集合中的一个对象

db.collection.deleteMany()

删除集合中多个对象

db.collection.drop()

完全删除集合

db.collection.createIndex()

如果索引不存在,那么创建索引;如果索引存在就不起占用

db.getSiblingDB()

使用相同的连接返回对另一个数据库的引用,而不显式切换当前数据库。这允许跨数据库查询。

交互式命令行快捷键

Keystroke

Function

Up-arrow

历史命令切换

Down-arrow

历史命令切换

交互式命令行查询

在mongo shell中,使用find() 和 findone()方法执行读取操作。

find()方法返回一个光标对象,mongo shell迭代该对象以在屏幕上打印文档。默认情况下,mongo打印前20个。MongoShell将提示用户“Type it”以继续迭代接下来的20个结果。

下表提供了mongo shell中的一些常见读取操作:

  • db.collection.find(< query>)
    如果< query > 为空,查询所有;否则返回满足要求的。

 coll = db.users; 

 coll.find( { name: "Joe" });

  • db.collection.find(< query>, < projection>)
    查找符合< query>条件的文档,并仅返回< projection>中的特定字段。

coll = db.users;

coll.find( { }, { name: true } );

db.collection.find().sort(< sort order>)
按照指定顺序返回,-1表示降序

coll = db.users;

coll.find().sort( { name: 1 } );

  • db.collection.find(< query>).sort(< sort order>)
    返回与指定的<排序顺序>中的<查询>条件匹配的文档。
  • db.collection.find( … ).limit( )
    将结果限制为< n>行
  • db.collection.find( … ).skip( )
    跳过< n>结果
  • db.collection.find(< query>).count()
    返回与查询匹配的文档总数。
    count()忽略limit()和skip()。例如,如果100条记录匹配,但限制为10,则count()将返回100。这比迭代自己快,但仍需要时间。
  • db.collection.findOne()
    查找并返回单个文档。如果找不到,则返回null。
    内部实现: findOne() = find()+ limit(1).

coll = db.users;

coll.findOne( { name: "Joe" } );

错误检查方法

Changed in version 2.6.

mongo shell write方法现在直接将写问题集成到方法执行中,而不是与单独的db.getLastError()方法集成。因此,write方法现在返回一个writeResult()对象,该对象包含操作的结果,包括任何写入错误和写入问题错误。

以前的版本使用db.getLastError()和db.getLastErrorObj()方法返回错误信息。

管理命令帮助程序

下表列出了一些支持数据库管理的常用方法:

方法

描述

db.cloneDatabase(< host>)

从指定的< host>克隆当前数据库。< host>数据库实例必须处于noauth模式。

db.copyDatabase(< from>, < to>, < host>)

将< from>数据库从< host>复制到当前服务器上的< to>数据库。< host>数据库实例必须处于noauth模式。

db.fromColl.renameCollection(< toColl>)

将集合从fromcoll重命名为< tocoll>

db.getCollectionNames()

获取当前数据库中所有集合的列表。

db.dropDatabase()

删除数据库

更多请参考 administrative database methods

其他

  • Object.bsonsize()
    打印的bson大小(字节)

bsonsize(db.getCollection('account').find({}).limit(1))

js的全部方法请参考 MongoDB JavaScript API Documentation

mongo 导出导入命令详解:

mongoexport 选项 如下
–host 指定mongo的ip和端口
-d 指定数据库名
-c 指定表名
-f 指定列名 (逗号隔开)
-o 指定输出路径
-q 指定查询语句

--type 执行文件类型

进入mongoexport所在目录:

mongoexport --host ip:27017 -u user -p password --authenticationDatabase admin -d databaseName -c collectionname --type=csv -f name -o ./record.csv -q ‘{“uptime”:{"$gte":1555286670}}’

mongoexport --host 192.168.0.221 --port 20058 -d test -c salary --type json --out D:\abc.json

mongoexport -d myDB -c user -f _id,name,password,adress --csv -o ./user.csv

导入mongoimport:

–host 指定mongo的ip和端口
-d 指定数据库名
-c 指定表名
--file 指定输入路径
-q 指定查询语句

--type 执行文件类型

mongoimport --host 192.168.0.221 --port 20058 -d test -c salary --type json --file D:\abc.json

参考:https://docs.mongodb.com/manual/tutorial/write-scripts-for-the-mongo-shel

https://docs.mongodb.com/manual/core/shell-types/

https://docs.mongodb.com/manual/reference/mongo-shell/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值