MongoDB学习(一)MongoDB常用命令

本文介绍了MongoDB中的数据库和集合的基本操作,包括创建、删除数据库,插入、更新、删除文档,以及查询文档的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.创建数据库

创建语法:

use DATABASE_NAME

如果数据库不存在,则创建数据库,否则切换到指定数据库。
创建yyf_mongodb数据库,db显示当前数据库

> use yyf_mongodb
switched to db yyf_mongodb
> db
yyf_mongodb

如果你想查看所有数据库,可以使用 show dbs 命令:

> show dbs
local  0.078GB

可以看到,我们刚创建的数据库 runoob 并不在数据库的列表中,要显示此数据库,需要向其中插入数据

> db.yyf_mongodb.insert({"name":"123"})
WriteResult({ "nInserted" : 1 })
> show dbs
local        0.078GB
yyf_mongodb  0.078GB

2.删除数据库

删除语法:

db.dropDatabase()

删除创建的yyf_mongodb数据库

#切换到yyf_mongodb数据库
> use yyf_mongodb
switched to db yyf_mongodb
#执行删除命令
> db.dropDatabase()
{ "dropped" : "yyf_mongodb", "ok" : 1 }

通过 show dbs 命令数据库是否删除成功:

> show dbs
local  0.078GB

3.删除集合

集合删除语法格式如下:

db.collection.drop()

4.插入文档

文档的数据结构和JSON基本一样。
MongoDB 使用 insert() 或 save() 方法向集合中插入文档,语法如下:

db.COLLECTION_NAME.insert(document)

向yyf_mongodb中插入文档:

> db.col.insert({url:"http://localhost",
    description:'127.0.0.1',
    by:'55'})
WriteResult({ "nInserted" : 1 })

集合名为col,如果该集合不在该数据库中, MongoDB 会自动创建该集合并插入文档
查看集合:

> db.col.find()
{ "_id" : ObjectId("59cdf6b516664e819555461d"), "url" : "http://localhost", "description" : "127.0.0.1", "by" : "55" }

3.2 版本后还有以下几种语法可用于插入文档:
db.collection.insertOne():向指定集合中插入一条文档数据
db.collection.insertMany():向指定集合中插入多条文档数据

db.collection.insertMany([{"b": 3}, {'c': 4}])

5.更新文档

update() 方法
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.insert({url:"http://localhost", description:'127.0.0.1', by:'55'})
WriteResult({ "nInserted" : 1 })

更新文档:

> db.col.update({'by':'55'},{$set:{'by':'66'}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.col.find()
{ "_id" : ObjectId("59cdfbb616664e819555461f"), "url" : "http://localhost", "description" : "127.0.0.1", "by" : "66" }

以上语句只会修改第一条发现的文档,如果你要修改多条相同的文档,则需要设置 multi 参数为 true。

>db.col.update({'by':'55'},{$set:{'by':'66'}},{multi:true})

6.删除文档

remove() 方法的基本语法格式如下所示:

db.collection.remove(
   <query>,
   <justOne>
)

如果你的 MongoDB 是 2.6 版本以后的,语法格式如下:

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

参数说明:
query :(可选)删除的文档的条件。

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

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

移除by为66的文档

> db.col.remove({'by':'66'})
WriteResult({ "nRemoved" : 2 })
> db.col.find()
...     #无数据

如果你只想删除第一条找到的记录可以设置 justOne 为 1,如下所示:

>db.COLLECTION_NAME.remove(DELETION_CRITERIA,1)

现在官方推荐使用 deleteOne() 和 deleteMany() 方法。
如删除集合下全部文档:

db.inventory.deleteMany({})

删除 status 等于 A 的全部文档:

db.inventory.deleteMany({ status : "A" })

删除 status 等于 D 的一个文档:

db.inventory.deleteOne( { status: "D" } )

7.查询文档

MongoDB 查询数据的语法格式如下:

db.collection.find(query, projection)

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

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

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

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

and条件查询:

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

or 条件查询:

>db.col.find(
   {
      $or: [
         {key1: value1}, {key2:value2}
      ]
   }
).pretty()
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值