MongoDB

作者: xueyue77 | 来源:发表于2018-11-08 17:35 被阅读0次

在客户端指定数据库进行连接:(默认连接本机test数据库)

[mongod@MongoDB ~]$ mongo10.0.0.152/admin

MongoDB shell version: 3.2.8

connecting to: 10.0.0.152/admin

> db

admin

查看当前数据库版本

> db.version()

3.2.8

切换数据库

> use test;

switched to db test

显示当前数据库

> db

test

> db.getName()

test

查询所有数据库

> show dbs;

clsn  0.000GB

local  0.000GB

test  0.000GB

> show databases;

clsn  0.000GB

local  0.000GB

test  0.000GB

查看clsn数据库当前状态

>use clsn;

> db.stats()

{

    "db":"clsn",

    "collections":1,

    "objects":10000,

    "avgObjSize":80,

    "dataSize":800000,

    "storageSize":258048,

    "numExtents":0,

    "indexes":1,

    "indexSize":94208,

    "ok":1}

查看当前数据库的连接机器地址

> db.getMongo()

connection to 127.0.0.1

1.5.2 数据管理

创建数据库

> use clsn;

说明:

创建数据库:

当use的时候,系统就会自动创建一个数据库。

如果use之后没有创建任何集合。系统就会删除这个数据库。

删除数据库

> show dbs;

clsn  0.000GB

local  0.000GB

test  0.000GB

> use clsn

switched to db clsn

> db.dropDatabase()

{ "dropped" : "clsn", "ok" : 1 }

说明:

删除数据库:

  如果没有选择任何数据库,会删除默认的test数据库

创建集合

   方法一:

> use clsn;

switched to db clsn

> db.createCollection('a')

{ "ok" : 1 }

> db.createCollection('b')

{ "ok" : 1 }

   查看当前数据下的所有集合

> show collections;

a

b

> db.getCollectionNames()

[ "a","b"]

方法二:

  当插入一个文档的时候,一个集合就会自动创建。

>use clsn;

switched to db clsn

> db.c.insert({name:'clsn'});

WriteResult({ "nInserted":1 })

> db.c.insert({url:'http://blog.nmtui.com'});

WriteResult({ "nInserted":1})

   查看创建的合集

> db.getCollectionNames()

[ "a","b","c"]

   查看合集里的内容

> db.c.find()

{ "_id": ObjectId("5a4cbcea83ec78b7bea904f8"),"name":"clsn" }

{ "_id": ObjectId("5a4cbcfc83ec78b7bea904f9"),"url":"http://blog.nmtui.com"}

重命名集合

> db.c.renameCollection("clsn")

{ "ok":1 }

> db.getCollectionNames()

[ "a","b","clsn"]

   删除合集

> db.a.drop()true

> db.getCollectionNames()

[ "b","clsn"]

   插入1w行数据

>for(i=0;i<10000;i++){ db.log.insert({"uid":i,"name":"mongodb","age":6,"date":new Date()}); }

WriteResult({ "nInserted":1})

查询集合中的查询所有记录

> db.log.find()

注:默认每页显示20条记录,当显示不下的的情况下,可以用it迭代命令查询下一页数据。

> DBQuery.shellBatchSize=50;    # 每页显示50条记录50

app

> db.log.findOne()            # 查看第1条记录

app

> db.log.count()              # 查询总的记录数

app

> db.log.find({uid:1000});    # 查询UUID为1000的数据

删除集合中的记录数

>  db.log.distinct("name")      #  查询去掉当前集合中某列的重复数据

[ "mongodb" ]

> db.log.remove({})            #  删除集合中所有记录

WriteResult({ "nRemoved":10000 })  

> db.log.distinct("name")

[ ]

查看集合存储信息

> db.log.stats()          # 查看数据状态

> db.log.dataSize()      # 集合中数据的原始大小> db.log.totalIndexSize() # 集合中索引数据的原始大小> db.log.totalSize()      # 集合中索引+数据压缩存储之后的大小> db.log.storageSize()    # 集合中数据压缩存储的大小

pretty()使用

> db.log.find({uid:1000}).pretty()

{

    "_id": ObjectId("5a4c5c0bdf067ab57602f7c2"),

    "uid":1000,

    "name":"mongodb",

    "age":6,

    "date": ISODate("2018-01-03T04:28:59.343Z")

}

"show dbs" 命令可以显示所有数据的列表。

执行 "db" 命令可以显示当前数据库对象或集合。

运行"use"命令,可以连接到一个指定的数据库。

删除数据库:

use runoob

db.dropDatabase()

删除集合:db.collection.drop()

> use runoob

switched to db runoob

> show tables

site

> db.site.drop()

true

> show tables

创建集合:db.createCollection(name, options)

use test

db.createCollection("runoob")

db.createCollection("mycol", { capped : true, autoIndexId : true, size :    6142800, max : 10000 } )

在 MongoDB 中,你不需要创建集合。当你插入一些文档时,MongoDB 会自动创建集合。

> db.mycol2.insert({"name" : "菜鸟教程"})

删除集合:

db.collection.drop()

>use mydb

switched to db mydb

>show collections

mycol

mycol2

system.indexes

runoob

>db.mycol2.drop()

true

插入文档:db.COLLECTION_NAME.insert(document)

>db.col.insert({title: 'MongoDB 教程',  description: 'MongoDB 是一个 Nosql 数据库',    by: '菜鸟教程',url:'http://www.runoob.com',    tags: ['mongodb', 'database', 'NoSQL'],    likes: 100})

查看已插入文档:

> db.col.find()

更新文档:

update() 方法用于更新已存在的文档。语法格式如下:

db.collection.update(  <query>,  <update>,  {    upsert: <boolean>,    multi: <boolean>,    writeConcern: <document>  })

参数说明:

query : update的查询条件,类似sql update查询内where后面的。

update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的

upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。

multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。

writeConcern :可选,抛出异常的级别。

db.col.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}})

save() 方法:

save() 方法通过传入的文档来替换已有文档。语法格式如下:

db.collection.save(  <document>,  {    writeConcern: <document>  })

参数说明:

document : 文档数据。

writeConcern :可选,抛出异常的级别。

>db.col.save({    "_id" : ObjectId("56064f89ade2f21f36b03136"), "title" : "MongoDB", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "Runoob", "url" : "http://www.runoob.com", "tags" : [ "mongodb", "NoSQL" ], "likes" : 110})

删除文档:

db.collection.remove( <query>, { justOne: <boolean>, writeConcern: <document> })

参数说明:

query :(可选)删除的文档的条件。

justOne : (可选)如果设为 true 或 1,则只删除一个文档。

writeConcern :(可选)抛出异常的级别。

>db.col.remove({'title':'MongoDB 教程'})

查询文档:db.collection.find(query, projection)

query :可选,使用查询操作符指定查询条件

projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)。

如果你需要以易读的方式来读取数据,可以使用 pretty() 方法,语法格式如下:

>db.col.find().pretty()

pretty() 方法以格式化的方式来显示所有文档。

db.col.find().pretty()

and:>db.col.find({key1:value1, key2:value2}).pretty()

> db.col.find({"by":"菜鸟教程", "title":"MongoDB 教程"}).pretty()

or:>db.col.find( { $or: [     {key1: value1}, {key2:value2} ] }).pretty()

>db.col.find({$or:[{"by":"菜鸟教程"},{"title": "MongoDB 教程"}]}).pretty()

AND 和 OR 联合使用:

>db.col.find({"likes": {$gt:50}, $or: [{"by": "菜鸟教程"},{"title": "MongoDB 教程"}]}).pretty()

相关文章

网友评论

      本文标题:MongoDB

      本文链接:https://www.haomeiwen.com/subject/fqgwxqtx.html