mongoDB基础入门

mongodb简介

MongoDB是一个跨平台,面向文档的数据库,提供好性能,搞可用性和抑郁扩展。MongoDB是工作集合和文档上一种概念。

数据库

数据库是一个集合物理容器。每个数据库获取其自己设定在文件系统上的文件。一个单一的MongoDB服务器通常有多个数据库。

集合

集合是一组MongoDB的文件。他与一个RDBMS表示等效的。一个集合存在于数据库中。集合不强制执行模式。集合中的文档可以有不同的字段。通常情况下,在一个集合中的所有文件都是类似或相关目的。

文档

文档是一组键值对。文档具有动态模式。动态模式是指,在同一个集合的文件不必具有相同一组集合的文档字段或结构,并且相同的字段可以保持不同类型的数据。

实例文档
{
	_id: ObjectId(7df78ad8902c)
	title: 'mongoDB Overview',
	description: 'MongoDB is no sql database',
	by: 'yiibai tutorial',
	url: 'http://www.yiibai.com',
	tags: ['mongodb', 'database', 'NoSQL'],
	likes: 100,
	comments: [
		{
			user: 'user1',
			message: 'My first comment',
			dateCreated: new Date(2011,1,20,2,15),
		like: 0
		},
		{
			user: 'user2',
			message: 'My second comments',
			dateCreated: new Date(2011,1,25,7,45),
			like: 5
		}
	]
}
软件安装
linux安装mongoDB

sudo apt install mongodb
netstat -ant | grep 27017

windows安装mongoDB

https://www.mongodb.org/dl/win32/x86_64-2008plus-ssl 下载并安装
要将mongoDB加到环境变量中
C:\Program Files\MongoDB\Server\4.0\bin一般是这个目录
然后在cmd中运行mongo

一、操作mongoDB数据库

1、创建数据库

语法: use 数据库名
注意: 如果数据库不存在则创建数据库,否则切换到指定的数据库,如果刚刚创建的数据库不在列表内,如果要显示它,我们需要向刚刚创建的数据库中插入一些数据

	use school
	# 插入数据
	db.student.insert({name:'tom',age:18,gender:1})
2、删除数据库
	# 前提:使用当前数据库(use 数据库名)
	db.dropDatabase()
3、查看所有数据
	shwo dbs
4、查看当前正在使用的数据库
	a.db
	b.db.getName()
5、断开连接
	exit
6、查看命令api
	help

二、操作集合

1、查看当前数据库下有哪些集合
	show collections
2、创建集合

语法:db.集合名.insert({文档})

	db.student.insert({name:"tom",age:18,gender:1})

会自动创建一个student的集合

3、删除当前数据库中的集合

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

	db.class.drop()

三、文档操作

1、插入文档
  • 使用insert()方法插入文档
    语法:db.集合名.insert(文档)
    语法:db.集合名.insert([文档1,文档2,…,文档n])

插入多个学生

	db.student.insert({name:'lilei',age:18,gender:1})

插入多个学生

	db.student.insert([{name:"海妹妹", age:17, gender:0,address:"北京", isDelete:0},{name:"韩梅梅", age:20, gender:0,address:"上海", isDelete:0}])
  • 使用save()方法插入文档
    语法:db.集合名.save(文档)
    说明:如果不能指定id字段,save()方法类似于insert()方法。如果指定id字段,则会更新_id字段的数据
	db.student.save({name:"poi", age:22, gender:1,address:"石家庄", isDelete:0})
	db.student.save({_id:ObjectId("59950962019723fe2a0d8d17"),name:"poi", age:23, gender:1,address:"石家庄", isDelete:0})
2、文档更新
  • update()犯法用于更新已存在的文档

语法

	db.集合名.update(
		query,
		update,
		{
			upsert:<boolean>,
			multi:<boolean>,
		}
	)

参数说明:
query:update的查询条件,类似于sql里update语句内where后面的内容
update:update的对象和一些更新的操作符(set,inc)等,set直接更新,inc在原有的基础上累加后更新
upset:可选,如果不存在update的记录,是否当新数据插入,ture为插入,False为不插入,默认发False。
nulti:可选,mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就按照条件查找出来的数据全部更新

需求:将lilei的年龄更新为25

db.student.update({name:"lilei"},{$set:{age:25}})

累加:将名字为lilei的所有人的年龄加25

db.student.update({name:'lilei'},{$inc:{age:25}})

全改

db.student.update({name:"poi"},{$set:{age:42}},{multi:true}) 

#不插入,但是更新多条

db.aaa.update({name:'hule',age:44},{$set:{name:'hule22'}},false,true)

#如果不能匹配则插入,如果匹配则更新多条

db.aaa.update({name:'hule',age:44},{$set:{name:'hule55'}},true,true)
3、文档删除

说明:在执行remove()函数前,先执行find()命令来执行判断执行的条件是否存在是一个良好习惯

  • 语法:
	db.集合.remove(
		query,
		{
			justOne:<boolean>,
		}
	)
  • 参数说明:
    query:可选,删除的文档的条件
    justOne:可选,如果ture或1,则只删除一个文档
	db.student.remove({name:'poi'})
4、文档查询
  • find()方法

语法:db.集合名.find()
查询集合下所有的文档(数据)

	db.student.find()
  • find()方法查询指定列
语法:db.集合名.find(
	query,
	{
		<key>:1
		<key>:1
	}
)

参数说明:
query:查询条件
key:要显示的字段,1表示显示

db.student.find({gender:0},{name:1,age:1})
db.student.find({},{name:1,age:1})
  • pretty()方法以格式化的方式来显示文档
db.student.find().pretty()
  • findOne()方法查询匹配结果的第一条数据
db.student.findOne({gender:0})
5、查询条件操作符

作用:条件操作符用于比较两个表达式并从Mongodb集合中获取数据

  • 大于:$gt
# 语法
db.集合名.find({<key>:{$gt:<value>}})
# 示例
db.student.find({age:{$gt:20}})
  • 大于等于 - $gte
#语法:
db.集合名.find({<key>:{$gte:<value>}})
  • 小于 - $lt
#语法:
db.集合名.find({<key>:{$lt:<value>}})
  • 小于等于 - $lte
#语法:
db.集合名.find({<key>:{$lte:<value>}})
  • 大于等于 和 小于等于 - $gte 和 $lte
 #语法:
 db.集合名.find({<key>:{$gte:<value>,$lte:<value>}})
  • 等于 - :
#语法:
db.集合名.find({<key>:<value>})
  • 使用_id进行查询
#语法:
db.student.find({"_id":ObjectId("id值")})

#示例db.student.find({"_id":ObjectId("5995084b019723fe2a0d8d14")})
  • 查询某个结果集的数据条数
db.student.find().count()
  • 查询某个字段的值当中是否包含另一个值
#语法:示例:
db.student.find({name:/ile/})
  • 查询某个字段的值是否以另一个值开头
#示例:
db.student.find({name:/^li/})
6、条件查询and 和 or

a、AND条件

 #语法:
 db.集合名.find({条件1,条件2,……,条件n})
        
 #示例:
 db.student.find({gender:0,age:{$gt:16}})

b、OR条件

 #语法:
            db.集合名.find(
                {
                    $or:[{条件1},{条件2},……,{条件n}]
                }
            )
#示例:
db.student.find({$or:[{age:17},{age:{$gte:20}}]})

c、AND和OR联合使用

#语法:
            db.集合名.find(
                {
                    条件1,
                    条件2,
                    $or:[{条件3},{条件4}]
                }
            )
7、limit、skip

a、limit():读取指定数量的数据记录

db.student.find().limit(3)

b、skip():跳过指定数量的数据

db.student.find().skip(3)

c、skip与limit联合使用

通常用这种方式来实现分页功能

db.student.find().skip(3).limit(3)
8、排序
#语法:
db.集合名.find().sort({<key>:1|-1})
#示例:
db.student.find().sort({age:1})   

注意:1表示升序,-1表示降序

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值