`
jzkangta
  • 浏览: 161018 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

mongodb 基本操作(转)

阅读更多
原文:http://blog.csdn.net/interfacexhei/archive/2011/01/24/6161439.aspx

查询所有数据库列表


CODE:

> show dbs
如果想查看当前连接在哪个数据库下面,可以直接输入db

CODE:

> db
Admin想切换到test数据库下面

CODE:

> use test
switched to db test
> db
Test想查看test下有哪些表或者叫collection,可以输入

CODE:

> show collections
system.indexes
user想知道mongodb支持哪些命令,可以直接输入help

CODE:

> help
HELP
       show dbs                     show database names
       show collections             show collections in current database
       show users                   show users in current database
       show profile                 show most recent system.profile entries with time >= 1ms
       use <db name>                set curent database to <db name>
       db.help()                    help on DB methods
       db.foo.help()                help on collection methods
       db.foo.find()                list objects in collection foo
       db.foo.find( { a : 1 } )     list objects in foo where a == 1
       it                           result of the last line evaluated; use to further iterate如果想知道当前数据库支持哪些方法:

CODE:

> db.help();
DB methods:
       db.addUser(username, password) 添加数据库授权用户
       db.auth(username, password)                访问认证
       db.cloneDatabase(fromhost) 克隆数据库
       db.commandHelp(name) returns the help for the command
       db.copyDatabase(fromdb, todb, fromhost)  复制数据库
       db.createCollection(name, { size : ..., capped : ..., max : ... } ) 创建表
       db.currentOp() displays the current operation in the db
       db.dropDatabase()        删除当前数据库
       db.eval_r(func, args) run code server-side
       db.getCollection(cname) same as db['cname'] or db.cname
       db.getCollectionNames()        获取当前数据库的表名
       db.getLastError() - just returns the err msg string
       db.getLastErrorObj() - return full status object
       db.getMongo() get the server connection object
       db.getMongo().setSlaveOk() allow this connection to read from the nonmaster member of a replica pair
       db.getName()
       db.getPrevError()
       db.getProfilingLevel()
       db.getReplicationInfo()
       db.getSisterDB(name) get the db at the same server as this onew
       db.killOp() kills the current operation in the db
       db.printCollectionStats()   打印各表的状态信息
       db.printReplicationInfo()        打印主数据库的复制状态信息
       db.printSlaveReplicationInfo()        打印从数据库的复制状态信息
       db.printShardingStatus()                打印分片状态信息
       db.removeUser(username) 删除数据库用户
       db.repairDatabase() 修复数据库
       db.resetError()
       db.runCommand(cmdObj) run a database command.  if cmdObj is a string, turns it into { cmdObj : 1 }
       db.setProfilingLevel(level) 0=off 1=slow 2=all
       db.shutdownServer()
       db.version() current version of the server如果想知道当前数据库下的表或者表collection支持哪些方法,可以使用一下命令如:

CODE:

> db.user.help();  user为表名
DBCollection help
       db.foo.count()                统计表的行数
       db.foo.dataSize()        统计表数据的大小
       db.foo.distinct( key ) - eg. db.foo.distinct( 'x' )                按照给定的条件除重
       db.foo.drop() drop the collection 删除表
       db.foo.dropIndex(name)  删除指定索引
       db.foo.dropIndexes() 删除所有索引
       db.foo.ensureIndex(keypattern,options) - options should be an object with these possible fields: name, unique, dropDups  增加索引
       db.foo.find( [query] , [fields]) - first parameter is an optional query filter. second parameter is optional set of fields to return. 根据条件查找数据
-----------------------
通过条件查询: db.foo.find( { x : 77 } , { name : 1 , x : 1 } )
-----------------------------
       db.foo.find(...).count()
       db.foo.find(...).limit(n) 根据条件查找数据并返回指定记录数
       db.foo.find(...).skip(n)
       db.foo.find(...).sort(...) 查找排序
       db.foo.findOne([query]) 根据条件查询只查询一条数据
       db.foo.getDB() get DB object associated with collection  返回表所属的库
       db.foo.getIndexes() 显示表的所有索引
       db.foo.group( { key : ..., initial: ..., reduce : ...[, cond: ...] } ) 根据条件分组
       db.foo.mapReduce( mapFunction , reduceFunction , <optional params> )
       db.foo.remove(query) 根据条件删除数据
       db.foo.renameCollection( newName ) renames the collection  重命名表
       db.foo.save(obj) 保存数据
       db.foo.stats()  查看表的状态
       db.foo.storageSize() - includes free space allocated to this collection 查询分配到表空间大小
       db.foo.totalIndexSize() - size in bytes of all the indexes 查询所有索引的大小
       db.foo.totalSize() - storage allocated for all data and indexes 查询表的总大小
       db.foo.update(query, object[, upsert_bool]) 根据条件更新数据
       db.foo.validate() - SLOW 验证表的详细信息
       db.foo.getShardVersion() - only for use with shardingMongodb的备份工具mongodump

如果想备份数据库test 如:

CODE:

[falcon@www.fwphp.cn  ~/mongodb/bin]$ ./mongodump --help
options:
--help                   produce help message
-h [ --host ] arg        mongo host to connect to
-d [ --db ] arg          database to use
-c [ --collection ] arg  collection to use (some commands)
-u [ --username ] arg    username
-p [ --password ] arg    password
--dbpath arg             directly access mongod data files in this path,
                          instead of connecting to a mongod instance
-v [ --verbose ]         be more verbose (include multiple times for more
                          verbosity e.g. -vvvvv)
-o [ --out ] arg (=dump) output directory
[falcon@www.fwphp.cn  ~/mongodb/bin]$ ./mongodump -d test -o test/
connected to: 127.0.0.1
DATABASE: test         to         test/test
       test.user to test/test/user.bson
                100000 objects
       test.system.indexes to test/test/system.indexes.bson
                1 objects
[falcon@www.fwphp.cn  ~/mongodb/bin]$ ls
2     mongo   mongodump    mongofiles   mongorestore  mongosniff
dump  mongod  mongoexport  mongoimport  mongos     testMongoDB的数据恢复工具mongorestore

查看test库中的表

CODE:

> show collections
system.indexes
User删除user表

CODE:

> db.user.drop();
True

> show collections
System.indexes现在利用mongorestore表恢复刚才利用mongodump备份的数据

CODE:

[falcon@www.fwphp.cn  ~/mongodb/bin]$ ./mongorestore --help
usage: ./mongorestore [options] [directory or filename to restore from]
options:
--help                  produce help message
-h [ --host ] arg       mongo host to connect to
-d [ --db ] arg         database to use
-c [ --collection ] arg collection to use (some commands)
-u [ --username ] arg   username
-p [ --password ] arg   password
--dbpath arg            directly access mongod data files in this path,
                         instead of connecting to a mongod instance
-v [ --verbose ]        be more verbose (include multiple times for more
                         verbosity e.g. -vvvvv)

[falcon@www.fwphp.cn  ~/mongodb/bin]$ ./mongorestore -d test -c user test/test/user.bson
connected to: 127.0.0.1
test/test/user.bson
        going into namespace [test.user]

        100000 objectsUser表中的10w条记录已经恢复

CODE:

> show collections
system.indexes
user
> db.user.find();
{ "_id" : ObjectId("4b9c8db08ead0e3347000000"), "uid" : 1, "username" : "Falcon.C-1" }
{ "_id" : ObjectId("4b9c8db08ead0e3347010000"), "uid" : 2, "username" : "Falcon.C-2" }
{ "_id" : ObjectId("4b9c8db08ead0e3347020000"), "uid" : 3, "username" : "Falcon.C-3" }
{ "_id" : ObjectId("4b9c8db08ead0e3347030000"), "uid" : 4, "username" : "Falcon.C-4" }
{ "_id" : ObjectId("4b9c8db08ead0e3347040000"), "uid" : 5, "username" : "Falcon.C-5" }
.................
has more





   1. 超级用户相关:

         #增加或修改用户密码

         db.addUser('admin','pwd')

         #查看用户列表

         db.system.users.find()

         #用户认证

         db.auth('admin','pwd')

         #删除用户

         db.removeUser('mongodb')

         #查看所有用户

         show users

         #查看所有数据库

         show dbs

         #查看所有的collection

         show collections

         #查看各collection的状态

         db.printCollectionStats()

         #查看主从复制状态

         db.printReplicationInfo()

         #修复数据库

         db.repairDatabase()

         #设置记录profiling,0=off 1=slow 2=all

         db.setProfilingLevel(1)

         #查看profiling

         show profile

         #拷贝数据库

         db.copyDatabase('mail_addr','mail_addr_tmp')

         #删除collection

         db.mail_addr.drop()

         #删除当前的数据库

         db.dropDatabase()

   2. 客户端连接

          /usr/local/mongodb/bin/mongo user_addr -u user -p 'pwd'

   3. 增删改

           #存储嵌套的对象

          db.foo.save({'name':'ysz','address':{'city':'beijing','post':100096},'phone':[138,139]})

          #存储数组对象

          db.user_addr.save({'Uid':'yushunzhi@sohu.com','Al':['test-1@sohu.com','test-2@sohu.com']})

          #根据query条件修改,如果不存在则插入,允许修改多条记录

          db.foo.update({'yy':5},{'$set':{'xx':2}},upsert=true,multi=true)

          #删除yy=5的记录

          db.foo.remove({'yy':5})

          #删除所有的记录

         db.foo.remove()

   4. 索引

          增加索引:1(ascending),-1(descending)

          db.things.ensureIndex({firstname: 1, lastname: 1}, {unique: true});

          #索引子对象

          db.user_addr.ensureIndex({'Al.Em': 1})

          #查看索引信息

          db.deliver_status.getIndexes()

          db.deliver_status.getIndexKeys()

          #根据索引名删除索引

          db.user_addr.dropIndex('Al.Em_1')

   5. 查询

          查找所有

          db.foo.find()

          #查找一条记录

          db.foo.findOne()

          #根据条件检索10条记录

          db.foo.find({'msg':'Hello 1'}).limit(10)

          #sort排序

          db.deliver_status.find({'From':'yushunzhi@sohu.com'}).sort({'Dt',-1})

          db.deliver_status.find().sort({'Ct':-1}).limit(1)

         #count操作

         db.user_addr.count()

         #distinct操作

         db.foo.distinct('msg')

         #>操作

         db.foo.find({"timestamp": {"$gte" : 2}})

         #子对象的查找

         db.foo.find({'address.city':'beijing'})

   6. 管理

          查看collection数据的大小

          db.deliver_status.dataSize()

          #查看colleciont状态

          db.deliver_status.stats()

          #查询所有索引的大小

          db.deliver_status.totalIndexSize()








MySQL:
SELECT * FROM user
Mongo:
db.user.find()
——————————————
MySQl:
SELECT * FROM user WHERE name = 'foobar'
Mongo:
db.user.find({ 'name' : 'foobar' })
——————————————
MySql:
INSERT INTO user ('name','age') VALUES ('foobar',25)
Mongo:
db.user.insert({ 'name' : 'foobar' , 'age' : 25})
——————————————
如果想增加email这一列
MySql:
ALTER TABLE user ...
Mongo:
db.user.insert({ 'name' : 'foobar' , 'age' : 25 , 'email' : 'foo@bar.com' })
——————————————
MySql:
DELETE * FROM user
Mongo:
db.user.remove({})
——————————————
MySql:
DELETE FROM user WHERE age < 30
Mongo:
db.user.remove({ 'age' : {$lt : 30}})
$gt:> ; $gte:>= ; $lt:< ; $lte:<= ; $ne:!=
——————————————
MySql:
UPDATE user SET `age` = 36 WHERE `name` = 'foobar'
Mongo:
db.user.update({ 'name' : 'foobar'} , {$set : { 'age' : 36}})
——————————————
MySQL:
UPDATE user SET `age` = 'age' + 3 WHERE `name` = 'foobar'
Mongo:
db.user.update({ 'name' : 'foobar'} , {$inc : {'age' : 3}})
——————————————
MySQl:
SELECT COUNT(*) FROM user WHERE `name` = 'foobar'
Mongo:
db.user.find({ 'name' : 'foobar'}).count()
——————————————
MySql:
SELECT * FROM user limit 10,20
Mongo:
db.user.find().skip(10).limit(20)
——————————————
MySQl:
SELECT * FROM user WHERE `age` IN (25,35,45)
Mongo:
db.user.find({ 'age' : {$in : [25,35,45]}})
——————————————
MySql:
SELECT * FROM user ORDER BY age DESC
Mongo:
db.user.find().sort({ 'age' : -1})
——————————————
MySQL:
SELECT DISTINCT(name) FROM user WHERE age > 20
Mongo:
db.user.distinct( 'name',{'age' : {$lt : 20}})
——————————————
MySQL:
SELECT name, sum(marks) FROM  user GROUP BY name
Mongo:
db.user.group({
key:{'name':true},
cond:{'name':'foo'},
reduce:function(obj,prev){prev.msum += obj.marks;},
initial:{msum : 0}
})
——————————————
MySQL:
SELECT name FROM user WHERE age < 20
Mongo:
db.user.find('this.age < 20' , {name : 1})

http://www.mongodb.org/display/DOCS/OR+operations+in+query+expressions


模糊查询

   //条件查询  模糊查询
                Pattern john = Pattern.compile("586190",Pattern.CASE_INSENSITIVE);
                BasicDBObject query = new BasicDBObject("url", john); // finds all people with "name" matching /joh?n/i DBCursor cursor = collection.find(query);
                DBCursor ite = col.find(query);


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/interfacexhei/archive/2011/01/24/6161439.aspx
分享到:
评论

相关推荐

    MongoDB基本操作指南

    MongoDB基本操作指南 MongoDB基本操作指南 MongoDB基本操作指南MongoDB基本操作指南

    nosql实验六- MongoDB的安装与基本操作.docx

    MongoDB 安装与基本操作 MongoDB 是一款流行的 NoSQL 数据库,广泛应用于大数据和实时 Web 应用程序。在本实验中,我们将学习如何在 Windows 和 Linux 环境下安装 MongoDB,并了解 MongoDB 的基本操作。 一、...

    mongodb 数据库基本操作.doc

    ### MongoDB数据库基本操作详解 #### 一、连接MongoDB数据库 MongoDB是一个广泛使用的开源文档数据库,支持多种编程语言。为了能够与MongoDB交互并执行各种数据库操作,首先需要通过官方提供的驱动程序或其他第三...

    MongoDB若基本操作

    在这个“MongoDB基本操作”的主题中,我们将深入探讨如何使用MongoDB进行数据的增删改查以及其它关键操作。 1. **安装与启动MongoDB** - 在不同的操作系统(如Windows、Linux或macOS)上安装MongoDB的步骤略有不同...

    MongoDB基本操作.docx

    ### MongoDB基本操作详解 #### MongoDB简介 MongoDB是一款开源的NoSQL数据库系统,以其灵活性、高性能及可扩展性著称,特别适用于Web应用的开发。MongoDB的数据模型基于文档,这意味着它存储的数据形式类似于JSON...

    mongodb数据库的基本操作

    在本文中,我们将深入探讨“mongodb数据库的基本操作”,包括增、删、改、查以及分页功能。 首先,让我们从创建数据库开始。在MongoDB中,数据库是存储数据的基本单位。通过运行`use &lt;database_name&gt;`命令,你可以...

    MongoDB基本操作之Python篇

    本文主要介绍在Python环境下如何进行MongoDB的基本操作。 首先,我们需要了解MongoDB在Python中的两种连接数据库的方式:MongoClient和Connection。从继承关系来看,Connection是MongoClient的子类。这意味着...

    MONGODB基本操作封装类

    将mongodb的基本操作,增删查询等封装为一个基本类供人调用

    MongoDB数据库及基本操作.txt

    mongodb 数据库基本操作mongodb 数据库基本操作mongodb 数据库基本操作mongodb 数据库基本操作mongodb 数据库基本操作mongodb 数据库基本操作mongodb 数据库基本操作mongodb 数据库基本操作mongodb 数据库基本操作...

    Mongodb基本操作

    MongoDB基本操作 MongoDB是一个基于分布式文件存储的NoSQL数据库,具有高性能、可扩展性强、易于使用等特点。下面将详细介绍MongoDB的基本操作。 一、启动和停止MongoDB 1. 启动MongoDB:使用以下命令启动MongoDB...

    mongoDb 基本操作 整理word

    本文主要概述了MongoDB的基本操作,包括安装、启动、数据库管理以及集合的操作。 首先,安装MongoDB非常简单,可以从官方网站下载适合您系统的版本。在Windows环境下,可以选择不解压或解压模式来运行。不解压模式...

    MongoDB基本操作手册1

    "MongoDB基本操作手册1" MongoDB 是一种开源、高性能、无模式的文档数据库,主要应用于解决高并发、海量数据的访问和存储,对数据库的高扩展性和高可用性。常见应用场景包括社交、游戏、物流、物联网、直播等等。 ...

    MongoDB基本操作-读取MongoDB中的数据.pdf

    ### MongoDB基本操作——读取MongoDB中的数据 #### 一、引言 MongoDB是一款流行的NoSQL数据库系统,因其灵活性和高性能而广泛应用于各种场景。本文档将指导您完成从MongoDB读取数据的基本操作。这包括连接到MongoDB...

    玩转MongoDB4.0从入门到实践、MongoDB基本操作之CRUD、进阶之聚合、中索引的重要性、数据分片

    #### 二、MongoDB基本操作之CRUD 这一章节将详细介绍MongoDB中的基本操作——创建(Create)、读取(Retrieve)、更新(Update)和删除(Delete),即CRUD操作: 1. **插入文档**:利用`insert`或`insertOne`命令插入单个...

    mongodb 数据库基本操作 使用MongoDB Python操作NoSQL数据库

    在这个话题中,我们将探讨如何使用Python进行MongoDB的基本操作,包括连接数据库、创建集合、插入文档、查询数据以及更新和删除记录。 首先,我们需要安装PyMongo库。可以使用pip命令来完成安装: ``` pip install ...

    MongoDB数据库基本操作指南

    MongoDB数据库基本操作指南

    mongodb 数据库基本操作

    对于工作1-3年的运维人员来说,掌握MongoDB的基本操作是提升工作效率的重要一环。下面我们将详细介绍MongoDB数据库的基本操作。 1. 安装与启动MongoDB: 在不同的操作系统上,安装MongoDB的步骤略有不同。通常,你...

    mongodb的基本命令.md

    mongodb基本操作数据库命令

    c#操作MongoDB基本功能

    本篇文章将深入探讨如何使用C#实现MongoDB的基本操作,包括增、删、改、查。 首先,我们需要引入MongoDB的C#驱动程序,这可以通过NuGet包管理器安装`MongoDB.Driver`库。安装完成后,我们可以创建一个`MongoClient`...

Global site tag (gtag.js) - Google Analytics