初学mongoDB(一)

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: 初学mongoDB

mongoDB的基本操作

查看数据库

语法:show databases

效果:

af72d4d39ffa45c79e750739d7aa50cb.png

选择数据库

语法:use 数据库名称

效果:

bffb1744c2bd4ebb9a69e0071fe66feb.png

删除数据库

1.通过use选中数据库

2.通过db.dropDatabase()删除数据库

创建集合

语法:db.createCollection("集合名")

效果:

266af65850414c71876a47d72915c5e6.png

查看集合

语法:show collections

效果:

266af65850414c71876a47d72915c5e6.png

删除 集合

语法:db.集合名.drop()

效果:

018be507260e4f05b74f8c7d6d06be34.png

mongoDB文档的增删改查

增Create

语法:db.集合名.insert(JSON数据)

说明:集合存在则直接插入数据,集合不存在则隐式创建

练习:在test2数据库的c1集合中插入数据

use test2 
db.c1.insert({name:"yyqx",age:18})
/*注:
1.数据库和集合不存在都隐式创建
2.对象的键统一不加引号方便看,但是查看集合时系统会自动加
3.mongodb会给每条数据增加一个全球唯一的_id值
*/

aff92765662641e28720cfc93cd86fc4.png

注:

1.可以自己定义id值,只需在传入的对象中加一个_id的键

db.c1.insert({name:"ys",age:18,_id:1})

b9a607665809454b9d7c571099ca35f3.png

2.可以一次插入多条信息,使用一个数组

db.c1.insert([
  {name:"z3",age:3},
  {name:"z4",age:3},
  {name:"w5",age:3}
])

43114f31eb234b37a64560be3f09cf15.png

3.可以使用for循环插入多条信息

for(var i = 1;i <= 10;i++){
  db.c2.insert({name:"z"+ i,age:i})
}

2c689640bb0345c08a02918326d3bdf7.png

查Read

基础语法:db.集合名.find(条件[,查询的列])

条件:

  • 查询所有数据 -{}或者不写
  • 查询age=6的数据 -{age:6}
  • 既要age=6又要性别=男 -{age:6 ,sex:‘男’}

查询的列(可选参数):

  • 不写–这查询全部列
  • {age:1}只显示age列
  • {age:0}除了age列

注:不管你怎么写系统自定义的_id都会在

升级语法

db.集合名.find({键:值})注:值不直接写
    {运算符:值}
db.集合名.find({
  键:{运算符:值}
})

注:格式化:db.集合名.find().pretty()

运算符 作用

$gt 大于

$gte 大于等于

$lt 小于

$lte 小于等于

$ne 不等于

$in in

$nin not in

练习1:查询所有数据

8199c493e9c540f9827ca36925bbac57.png

练习2:查询年龄大于5岁的数据?

3a4d8d9e47c14397bbde58a53dccdf5c.png

练习3:查询年龄是5岁、8岁、10岁的数据?

95e52c93b55a40aaaff61a40e0d38472.png

练习4:只看年龄列,或者年龄以外的列(_id别管它)?

30077ffce7b247edb2d5544a3bfcb2b2.png

改Update

基础语法: db.集合名.update(条件,新数据〔,是否新增,是否修改多条])

  • 是否新增:指条件匹配不到数据则插入(true是插入,false否不插入默认)
  • 是否修改多条:指将匹配成功的数据都修改(true是,false否默认)

升级语法

db.集合名.update(条件,新数据)
      {修改器:{键:值}}

修改器 作用

$inc 递增

$rename 重命名列

$set 修改列值

$unset 删除列

练习1:将{uname:“zs1"”}改为{uname:“zs2"”

7077213e986f4a868816562843aab521.png

发现:默认是修改而不是替换

解决:使用升级语法 修改器

9fa285e153d94871a7e175f9e43d14ec.png

练习2:给{uname:“zs10”}的年龄加2岁或者减2岁

e2f97275fa7f4a7aaacae128c11ace6b.png

练习3:修改器综合练习

插入数据: db.c4.insert( {uname:“神龙教主”,age:888,who:“男”,other:“非国人”});

完成需求:

uname改成yyds  (修改器:$set)
age增加111     (修改器:$inc)
who改字段sex   (修改器: $rename)
other 删除     (修改器: $unset)

d72dfa06c1f04cf384aee10dbe87634a.png

练习4:验证语法最后两个参数(了解)

【验证】是否新增true是false否:修改name等于zs30的年龄30岁

91f9c03cbb1b4b3e8de466cd42d92099.png

【验证】是否修改多条true是,false否默认

8c0e7d244a1f454fb58911ebf05a9059.png

612fd099e64b4d6a8275a7f9f057dca6.png

删Delete

语法: db.集合名.remove(条件[是否删除一条])

注意:是否删除—条true是,false否默认

9f7f087b5b974144b8e73e12a881ee92.png

排序与分页

排序

  • 语法:db.集台名.find().sort(JSON数据)
  • 说明:键-就是要排序的列/字段、值:1升序-1降序
  • 练习:年龄升序&降序

08b10eccb14c44539b22248dcfc45b09.png

分页(Limit与Skip方法)

语法: db.集合名.find().sort().skip(数字).limit(数字)

说明: skip跳过指定数量(可选),limit限制查询的数量

练习:1-降序查询查询2条,2-降序跳过2条并查询2条

168217e4e62f421dad69e10a7567d392.png

实战分页

语法: db.集合名.find().skip().limit(2)

需求:数据库1 -10数据,每页显示两条(5页)

skip计算公式:(当前页-1)*每页显示条数
1页   1 2     0
2页   3 4     2
3页   5 6     4
4页   7 8     6
5页   9 10    8

小总结

  • db.集合名.find()
  • sort({列: 1/-1})排序
  • skip(数字)跳过指定数量
  • limit(数字)限制查询条数
  • count()统计总数量


相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
3月前
|
NoSQL JavaScript MongoDB
MongoDB
【10月更文挑战第28天】
39 2
|
3月前
|
存储 分布式计算 NoSQL
什么是 MongoDB ?
10月更文挑战第10天
23 0
|
存储 NoSQL MongoDB
关于MongoDB
关于MongoDB
154 0
|
存储 NoSQL 定位技术
MongoDB的特点
MongoDB的特点
441 1
|
NoSQL Shell Linux
|
NoSQL 前端开发 MongoDB
MongoDB应用
初始化路由模板 数据库和前端页面交互 编写注册的后台接口 先连接数据库 和前台进行数据交互 文章的后台接口 先查询所有的文章内容 发文章 一些验证方法 邮箱验证 用户名随机生成
76 0
|
存储
MongoDB-片键选择技巧
使用分片的目的是为了将数据存储到不同的服务器上, 所以在选择片键的时候,应该选择取值范围更广的字段作为片键,因为如果取值范围太小, 那么划分出来的数据段就太少, 那么分配到不同服务器的概率就越小, 例如:取值如果只有 true 或 false, 那么就只能划分出两个数据段, 那么也就最多只能保存到两台服务器上。
97 0
|
SQL JSON NoSQL
老去的MongoDB,未来在哪里?
老去的MongoDB,未来在哪里?
258 0
|
存储 SQL 分布式计算
MongoDB的介绍
MongoDB的介绍
95 0
|
存储 缓存 NoSQL
MongoDB 使用介绍
MongoDB 是由 C++ 语言编写的,是一个基于分布式文件存储的非关系型开源数据库系统。其优势在于可以存放海量数据,具备强大的查询功能,是一个独立的面向集合文档形式的。
377 0
MongoDB 使用介绍