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使用指定的编辑器进行编辑,如下例所示:
- 定义函数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
- 查看集合对象(例如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位整数,表示自1970年1月1日以来的毫秒数。
并非所有的数据库操作和驱动程序都支持完整的64位范围。您可以安全地使用包含0到9999年的日期。
以字符串格式返回日期
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 users | 打印当前数据库的用户列表 |
show roles | 打印当前数据库的所有角色(用户定义的和内置的)列表 |
show profile | 打印最近5次操作,耗时1毫秒或更长时间。具体请参考profile。 |
load() | 执行JaveScript脚本,具体请参考为Mongo Shell编写脚本 |
交互式命令行常用操作:
在mongo shell中,db是引用当前数据库的变量。变量将自动设置为默认数据库测试,或者在使用切换当前数据库时设置。
api | 描述 |
如果在安全模式下运行,则对用户进行身份验证 | |
coll = db.< collection> | coll = db.myCollection; – coll.find(); |
查找集合或视图中的文档,并将光标返回到所选文档,参考 | |
db.collection.insertOne() | 插入一个新的对象到集合中 |
db.collection.insertMany() | 插入多个新对象到集合中 |
db.collection.updateOne() | 更新集合中一个已经存在的对象 |
db.collection.updateMany() | 更新集合种多个已经存在的对象 |
db.collection.save() | 插入新文档或更新集合中的现有文档 |
db.collection.deleteOne() | 删除集合中的一个对象 |
db.collection.deleteMany() | 删除集合中多个对象 |
完全删除集合 | |
如果索引不存在,那么创建索引;如果索引存在就不起占用 | |
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