首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mongo 笔记

mongo 笔记

作者头像
句小芒
发布2022-12-29 18:14:57
1.1K0
发布2022-12-29 18:14:57
举报
为什么要存在mongo

在以往的关系型数据库(如Mysql),使用表和列来对数据进行存储,进行数据查询操作。但是这样有一个弊端就是 1. 多表查询会比较复杂。 2.对数据类型要求严格,如果需要加字段会稍微麻烦一些。

在这里插入图片描述
在这里插入图片描述

mongo 是以数组或者对象来对数据进行存储,并且还可以嵌套。

# 进入mongo
$ mongo
# 显示所有数据库
> show dbs
# 创建数据库 使用use 命令,
> use gmtest
switched to db gmtest
# 查看当前db
> db
gmtest
# 查看所有db,发现我们创建的并不显示,需要插入数据才可以
> db.gmtest.insert({"name":"菜鸟果果"})
WriteResult({ "nInserted" : 1 })
> show dbs
admin     0.000GB
config    0.000GB
gmtest    0.000GB   #这条是我们刚新建的数据库
local     0.000GB

增删改查

## 增加数据
> db.gmtest.insert({"name":"菜鸟果果2"})
WriteResult({ "nInserted" : 1 })
### 增加一条数据 insertOne
> db.gmtest.insertOne({"name":"菜鸟果果3"})
{
	"acknowledged" : true,
	"insertedId" : ObjectId("6170fcb3ced87b0c142a3ba2")
}
### 同时插入多条数据
> db.gmtest.insertMany([{"name":"菜鸟果果4"},{"name":"菜鸟果果5","age":67}])
{
	"acknowledged" : true,
	"insertedIds" : [
		ObjectId("6170fcd8ced87b0c142a3ba3"),
		ObjectId("6170fcd8ced87b0c142a3ba4")
	]
}

## 查询数据
### 查询所有数据
> db.gmtest.find()
{ "_id" : ObjectId("6170e7d1ced87b0c142a3b9f"), "name" : "菜鸟果果" }
{ "_id" : ObjectId("6170e840ced87b0c142a3ba0"), "name" : "菜鸟果果2" }
{ "_id" : ObjectId("6170e8c8ced87b0c142a3ba1"), "name" : "菜鸟果果2" }
{ "_id" : ObjectId("6170fcb3ced87b0c142a3ba2"), "name" : "菜鸟果果3" }
{ "_id" : ObjectId("6170fcd8ced87b0c142a3ba3"), "name" : "菜鸟果果4" }
{ "_id" : ObjectId("6170fcd8ced87b0c142a3ba4"), "name" : "菜鸟果果5", "age" : 67 }
### 查询单条数据
> db.gmtest.findOne({"name":"菜鸟果果"})
{ "_id" : ObjectId("6170e7d1ced87b0c142a3b9f"), "name" : "菜鸟果果" }
### 多个where 进行查询  pretty: 返回数据更加美观,没啥大用
> db.gmtest.find({"name":"菜鸟果果5","age":67}).pretty()
{
	"_id" : ObjectId("6170fcd8ced87b0c142a3ba4"),
	"name" : "菜鸟果果5",
	"age" : 67
}
### 字段存在查询
> db.gmtest.find({"score":{$exists:true}})
### 关于算术运算符(参考下图),查询age 小于80
> db.gmtest.find({"age":{$gt:80}})
{
	"_id" : ObjectId("6170fcd8ced87b0c142a3ba4"),
	"name" : "菜鸟果果5",
	"age" : 67
}
### 更新数据  multi:   true(更新所有数据), false(更新一条数据), 默认是false
> db.gmtest.update({'name':'菜鸟果果5'},{$set:{'age':96}},{multi:true})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
#### 只更新一条数据
> db.gmtest.update({'name':'菜鸟果果2'},{$set:{'score':96}},{multi:false})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.gmtest.find()
{ "_id" : ObjectId("6170e7d1ced87b0c142a3b9f"), "name" : "菜鸟果果" }
{ "_id" : ObjectId("6170e840ced87b0c142a3ba0"), "name" : "菜鸟果果2", "score" : 96 }
{ "_id" : ObjectId("6170e8c8ced87b0c142a3ba1"), "name" : "菜鸟果果2" }
{ "_id" : ObjectId("6170fcb3ced87b0c142a3ba2"), "name" : "菜鸟果果3" }
{ "_id" : ObjectId("6170fcd8ced87b0c142a3ba3"), "name" : "菜鸟果果4" }

### 删除文档
> db.gmtest.deleteMany({'score':{$lt:100}})
{ "acknowledged" : true, "deletedCount" : 1 }

我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=2xsv85l2ljoko

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-12-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 为什么要存在mongo
  • 增删改查
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档