mongodb 常用命令

转自http://www.blogjava.net/waterjava/archive/2011/03/23/346819.html

命令行

--help 显示命令行参数
--nodb 不连接数据库方式启动,稍后可以使用 new Mongo() 或 connect() 来建立连接
--shell 从命令行运行完一个 .js 文件后,停留在shell中,而不是结束

特殊命令

非JavaScript的辅助指令:

help 显示帮助
db.help() 显示 db 方法帮助
db.myColl .help() 显示聚集的方法帮助
show dbs 打印服务器上所有数据库的列表
use dbname 设置db变量来指明使用服务器上的 dbname 数据库
show collections 打印当前数据库的所有聚集
show users 打印当前数据库的用户
show profile 打印最近耗时大于1ms的profiling操作

基本的Shell Javascript操作

db 指向当前数据库对象和连接的变量,已经在你的实例里定义好。
db.auth(user,pass) 数据库认证(如果运行安全模式的话)
coll = db.collection 访问数据库里特定的 collection
cursor = coll.find() 查找聚集里所有的对象。参考 [查询] 。
coll.remove(objpattern ) 从聚集里删除匹配的对象。 
objpattern 是一个指定匹配的域的对象,例如:coll.remove( { name: "Joe" } );
coll.save(object ) 在聚集中保存对象,如果已经存在的话则更新它。 
如果对象有 presave 方法,则会在保存到数据库之前(插入和更新之前)调用该方法。
coll.insert(object) 向聚集中插入对象。不会检查该对象是否已经存在聚集中(即,不是 upsert)
coll.update(...) 在聚集中更新对象。update() 有许多参数,请查看 更新 文档。
coll.ensureIndex( { name : 1 } ) 对 name 建索引。如果索引存在则不做任何事。
coll.drop() 删除 coll 聚集
db.getSisterDB(name) 返回当前连接的另一个数据库。它允许跨数据库查询,例如:db.getSisterDB(‘production‘).getCollectionNames()

查询

coll.find() 查询所有文档
it 循环上次 find() 调用返回的游标
coll.find( criteria ); 查询聚集中匹配 criteria 的对象。例如:coll.find( { name: "Joe" } );
coll.findOne( criteria); 查询并返回一个对象。如果没有找到则返回 null。如果你只需要返回一个对象,这个方法比 find() as limit(1) 效率更高。如果元素类型是字符串,数字或时间,你还可以使用正则表达式:coll.find( { name: /joe/i } );
coll.find( criteria, fields ); 查询对象里特定的域。例如:coll.find( {}, {name:true} );
coll.find().sort( {field :1[, field :1] }); 对返回结果进行排序(field ASC)。使用 -1 表示 DESC。
coll.find( criteria ).sort( { field : 1 } ) 查找匹配 criteria 的对象,并对 field 进行排序。
coll.find( ... ).limit(n ) 限制结果返回 n 行。如果你只需要某几行数据,推荐这样做来获得最优性能。
coll.find( ... ).skip(n) 跳过 n 行结果。
coll.count() 返回聚集里对象的总数。
coll.find( ... ).count() 返回匹配该查询的对象总数。注意,该返回会忽略 limit 和 skip。比如有100行记录匹配该查询,但是limit为10,count() 仍会返回100。这比你自己循环更快,但仍然需要消耗些时间。

更多信息请参考 [查询] 。

错误检查

[{{db.getLastError()}}] 返回上次操作的错误
db.getPrevError() 返回之前操作的错误
db.resetError() 清除错误记录

管理命令

db.cloneDatabase(fromhost) 从另外指定的主机拷贝当前数据数据库。fromhost必须为noauth模式。
db.copyDatabase(fromdb, todb, fromhost) 拷贝fromhost的fromdb数据库到当前服务器的todb数据库。fromhost必须为noauth模式。
db.repairDatabase() 修复当前数据库。如果数据库很大则该操作会非常慢。
db.addUser(user,pwd) 给当前数据库添加用户。
db.getCollectionNames() 获得所有聚集的列表。
db.dropDatabase() 删除当前数据库。

打开额外连接

db = connect("<host>:<port>/<dbname>") 打开一个新的数据库连接。一个shell可能有多个连接,但是shell自动的getLastError只用于 ‘db‘ 变量。
conn = new Mongo("hostname") 打开一个新的服务器连接。然后可以使用 getDB() 来选择一个数据库。
db = conn.getDB("dbname") 对一个连接选择一个特定的数据库。

其他

Object.bsonsize(db.foo.findOne()) 打印一个数据库对象的bson大小(mongo 版本1.3及以上)
db.foo.findOne().bsonsize()
打印一个数据库对象的bson大小 (mongo 版本1.3之前)

时间: 2024-08-08 01:09:07

mongodb 常用命令的相关文章

(转)mongodb常用命令脚本化-自动化运维

mongodb常用命令脚本化-自动化运维 把一些运维中常用到的mongodb命令写成shell脚本,极大的方便了维护 1 设置副本集 #!/bin/bash#mongodb 进入client 并use admincd /usr/mongodb/binMongoDB='./mongo 192.168.1.7:37017'$MongoDB <<EOFuse adminrsconf={        "_id" : "Job001",        "

MongoDB 常用命令总结

MongoDB 常用命令总结 简单的的增删改查数据 在查询结果中指定显示或者不显示某个字段 例如,我们希望在 lessons 集合中查找所有数据,但是不希望在返回结果中包含 slides 字段:因为 slides 是一个巨长的以 base64 表示的图片数组,影响查询结果的阅读. 那么我们就可以在 query object 后面跟上一个参数.如下: db.lessons.find({}, {slides:0}); 同样也可以明确指定显示哪些字段: db.bios.find( { }, { nam

[整理]MongoDB 常用命令总结

MongoDB 常用命令总结 简单的的增删改查数据 在查询结果中指定显示或者不显示某个字段 例如,我们希望在 lessons 集合中查找所有数据,但是不希望在返回结果中包含 slides 字段:因为 slides 是一个巨长的以 base64 表示的图片数组,影响查询结果的阅读. 那么我们就可以在 query object 后面跟上一个参数.如下: db.lessons.find({}, {slides:0}); 同样也可以明确指定显示哪些字段: db.bios.find( { }, { nam

mongodb常用命令脚本化-自动化运维

mongodb常用命令脚本化-自动化运维 把一些运维中常用到的mongodb命令写成shell脚本,极大的方便了维护 1 修改副本集的设置 #!/bin/bash #mongodb 进入client 并进入primary cd /usr/mongodb/bin MongoDB='./mongo 192.168.1.7:37017' $MongoDB <<EOF use MongoModelJobResume #rs.status() cfg=rs.conf() cfg.members[0].p

MongoDB常用命令

成功启动MongoDB后,再打开一个命令行窗口输入mongo,就可以进行数据库的一些操作. 1.输入help可以看到基本操作命令: show dbs:显示数据库列表 show collections:显示当前数据库中的集合(类似关系数据库中的表) show users:显示用户 use <db name>:切换当前数据库,这和MS-SQL里面的意思一样 db.help():显示数据库操作命令,里面有很多的命令 db.foo.help():显示集合操作命令,同样有很多的命令,foo指的是当前数据

MongoDB常用命令及例子详细介绍(三)

常用命令,及其高级命令使用介绍 一:增删改查的高级应用详细介绍: 增:***插入的时候c1不在的话将自动创建*** 不管插入那条记录都会自动给带个值id 自增主键唯一 insert 和 save(当id冲突是则修改,否则插入) 一:id主键不冲突的情况没区别 db.c1.insert({name:"leyangjun"}); db.c1.insert({name:"leyangjun"}); insert插入的值id都是唯一的,不会主键id冲突 db.c1.save

mongoDB常用命令与安全加固

一.介绍 MongoDB 是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案.MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型.Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引.它的特点是高

python | mongodb 常用命令

MongoDB是NoSQL数据库系统中比较流行的数据库之一.它也是最接近关系型数据库的,一个数据库可以包含多个集合(Collection),类似于关系数据库中的表:而每个集合中可以存储一组由列标识的记录,列是可以自由定义的,非常灵活,这就类似于关系数据库表中的每一条记录.下面和大家一起熟悉下MongoDB的基本管理命令. 一.MongoDB数据库常用命令 1.Help查看命令提示helpdb.help();db.yourColl.help(); 2.切换/创建数据库use raykaeso; 当

记一些 mongodb 常用命令

// 常用命令 show dbs // 查看所有数据库列表 db // 查看当前连接的是哪个库 use test // 新建数据库 & 切换到test库 db.dropDatabase() // 删库 show collections // 查看当前库下的集合(表) db.test.insert({"name":"willian"}) // 创建集合并插入数据 db.test.drop() // 删除表 db.test.find() // 查询所有记录 db

2. mongodb常用命令

数据库常用命令 1.Help查看命令提示 help db.help(); db.yourColl.help(); db.youColl.find().help(); rs.help(); 2.切换/创建数据库 use yourDB;  当创建一个集合(table)的时候会自动创建当前数据库 3.查询所有数据库 show dbs; 4.删除当前使用数据库 db.dropDatabase(); 5.从指定主机上克隆数据库 db.cloneDatabase(“127.0.0.1”); 将指定机器上的数