MongoDB常用知识学习

一.数据库的分类

数据库主要分为两类:
	1.关系型数据库(RDBMS)
		Mysql、Oracle、DB2、SQL Server
		关系型数据库全是表
	2..非关系型数据库(NoSql)
		MongoDB、redis
		键值对数据库
		文档数据库MongoDB

二.MongoDB简介

MongoDB是为快速开发互联网Web应用而设计的数据库系统
MongoDB的设计目标是极简、灵活、作为Web应用栈的一部分
MongoDB的数据模型是面向文档的,所谓文档是一种类似于JSON的结构,可以简单为理解MongoDB这个数据库中存的是各种各样的JSON

三.基本概念

数据库:数据库是一个仓库,在仓库中可以存放集合
集合:集合类似于数组,在集合中可以存放文档
文档:文档数据库中的最小单位,我们存储和操作的内容都是文档
--在MongoDB中,数据库和集合都不需要手动创建,当我们创建文档是,如果文档所在的集合或数据库不存在自动创建数据库和集合

四.基本指令

	show dbs -查看全数据库
	show databases -显示当前的所以数据库
	use 数据库名 -进入指定的数据库中
	db -表示的是当前所处的数据库
	show collections -显示数据库中所有的集合
	db.help(); -显示数据库操作命令,里面有很多的命令 
	db.foo.help(); -显示集合操作命令,同样有很多的命令,foo指的是当前数据库下,一个叫foo的集合,并非真正意义上的命令 
	db.foo.find(); -对于当前数据库中的foo集合进行数据查找(由于没有条件,会列出所有数据) 
	db.foo.find( { a : 1 } );  -对于当前数据库中的foo集合进行查找,条件是数据中有一个属性叫a,且a的值为1

五.基本语法

1.创建数据库
use DATABASE_NAME(表名)
> use test
switched to db test
> db
test
> 
2.删除数据库
db.dropDatabase()
3.创建集合
db.createCollection(name, options)
	-name: 要创建的集合名称
	-options: 可选参数, 指定有关内存大小及索引的选项
		options可以是如下参数:
			capped:如果为true,则创建固定集合。固定集合指有着固定大小的集合,当达到最大值时,它会自动覆盖最早的文件;如果为true,必须指定size参数
			autoIndexId:如为 true,自动在 _id 字段创建索引。默认为 false。
			size:为固定集合指定一个最大值
			ma:指定固定集合中包含文档的最大数量
在test数据库中创建user集合
> use test
switched to db test
> db.createCollection("user")
{ "ok" : 1 }
>
4.删除集合
db.collection.drop()
5.插入文档
db.COLLECTION_NAME.insert(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({title: 'xx', 
    description: 'xxxxxx',
    by: 'xxx',
    url: 'http://www.xxx.com',
    tags: ['a', 'b', 'c'],
    likes: 100
})
6.更新文档
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'}})
	修改多条相同的文档,需要设置 multi 参数为 true>db.col.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}},{multi:true})
7.删除文档
db.collection.remove(
   <query>,
   <justOne>
)
	删除第一条找到的数据
	>db.collection.remove(DELETION_CRITERIA,1)
	删除所有数据
	>db.col.remove({})
	>db.col.find()
>
8.查询文档
db.collection.find(query, projection)
	-query :可选,使用查询操作符指定查询条件
	-projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省	略)。
以易读的方式来读取数据,可以使用 pretty() 方法
>db.col.find().pretty()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值