MongoDB

数据库

什么是数据库

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据库技术得到了更加快速的发展,应用得更加广泛。主要用它进行管理各种系统的数据,作为科学研究和决策的重要技术手段。

常见的数据库有哪些:

关系型数据库(sql):Access mySql SqlServer oracle db2等。

非关系型数据库( NoSql ): MongoDB,Redis,HBase,CouchDB等。

MongoDB简介

MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。

MongoDB 是非关系型数据库当中功能最丰富,最像关系型数据库的。

随着大数据的不断发展,非关系型数据库已经变得越来越重要,相关的产品也都得到了飞速发展。而其中MongoDB更是佼佼者,作为高性能开源文档数据库,MongoDB以敏捷、可扩展和对企业应用友好而著称,因其操作简单、完全免费、源码公开等特点,受到了IT从业人员的青睐,并被广泛部署于实际的生产环境中。

使用MongoDB的公司包括:BAT、360、Foursquare、Craiglist,、迪士尼、SAP、Intuit、EA等。

很多大公司在用,并且越来越多的公司也要用,我们以后就可能接触到相关的项目,虽然数据库是后端人员做的事情,但是做为高级前端,有必要对它有所了解,才更好的和后端开发人员合作,做到知己知彼,百战不殆。

MongoDB优点

它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有:

· 面向集合存储,易存储对象类型的数据。

· 模式自由。

· 支持动态查询。

· 支持完全索引,包含内部对象。

· 支持查询。

· 支持复制和故障恢复。

· 使用高效的二进制数据存储,包括大型对象(如视频等)。

· 自动处理碎片,以支持云计算层次的扩展性

· 支持RUBY,PYTHON,JAVA,C++,PHP等多种语言。

· 文件存储格式为BSON(一种JSON的扩展)

非关系型数据库与关系型数据库区别

非关系型数据库的优势:

  1. 性能

NOSQL是基于键值对的,可以想象成表中的主键和值的对应关系,而且不需要经过SQL层的解析,所以性能非常高。

  1. 可扩展性

同样也是因为基于键值对,数据之间没有耦合性,所以非常容易水平扩展。

关系型数据库的优势:

  1. 复杂查询

可以用SQL语句方便的在多个表之间做非常复杂的数据查询。

  1. 事务支持

使得对于安全性能很高的数据访问要求得以实现。

总结:

  • 数据库功能是用来存储数据的。

  • 数据库分为关系系数据库和非关系型数据库(nosql)

  • 关系型数据库是由表和表之间的关系组成的,nosql是由集合组成的,集合下面是很多的文档。

  • 非关系型数据库文件存储格式为BSON(一种JSON的扩展)。

MongoDB基础命令**

1.启动mongodb服务

NET START MongoDB

​ 2.关闭和删除进程

先 ctrl+c

关闭服务:net stop MongoDB

3.Help 查看帮助

4.显示数据库列表 > show dbs

5.创建数据库 > use dbname

如果数据库不存在,则创建数据库dbname,否则切换到指定数据库dbname。创建的数据库并不在数据库的列表中,要显示它,我们需要向数据库dbname插入一些数据

MongoDB 中默认的数据库为 test,如果你没有创建新的数据库,集合将存放在 test 数据库中。

6.显示数据库中的集合 show collections

7.增加数据(重点中的重点)

db.web.save({“name”:“老李”}) 创建了名为web的集合,并新增了一条{“name”:“老李”} 的数据

db.web.insert({“name”:“ghost”, “age”:10}) 在web集合中插入一条新数据,如果没有web这个集合,mongodb会自动创建

save()和insert()也存在着些许区别:若新增的数据主键已经存在,insert()会不做操作并提示错误,而save() 则更改原来的内容为新内容。

_id是主键,主键是每条数据的唯一标识,不能重复,就像身份证是每个人唯一的编号一样。

存在数据:{ _id : ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老李"} ,_id是主键

insert({ _id : ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老王 " }) 会提示错误

  1. 删除数据(重点中的重点)

1、删除文档

2、删除集合

3、删除数据库

· db.users.remove({}) 删除users集合下所有数据

· db.users.remove({“name”: “lecaf”}) 删除users集合下name=”lecaf”的数据

· db.users.drop()或db.runCommand({“drop”:“users”}) 删除集合users

db.runCommand({“dropDatabase”: 1}) 删除当前数据库,注意 此处的1没加双引号

9查找数据(重点中的重点)

· db.users.find() 查找users集合中所有数据

· db.users.findOne() 查找users集合中的第一条数据

· db.users.find().pretty() 格式化查询到的数据

10.修改数据(重点中的重点)**

db.web.update({“name”:“a1”}, {$set: {sex:”women”}},true,true) 修改name=a1的数据为sex= women,第一个参数是查找条件,第二个参数是修改内容主键不能修改,第三个参数表示匹配所有符合条件的数据,第四个参数表示修改所有匹配到的数据

11.条件差查找

语法1:db.collection.find({ “key” : value }) 查找key=value的数据.

语法2: db.collection.find({ “key” : { $gt: value } }) key > value

语法3:db.collection.find({ “key” : { $lt: value } }) key < value

语法4:db.collection.find({ “key” : { $gte: value } }) key >= value

语法5:db.collection.find({ “key” : { $lte: value } }) key <= value

语法6:db.collection.find({ “key” : { $gt: value1 , $lt: value2 } }) value1 < key <value2

语法7:db.collection.find({ “key” : { $ne: value } }) key <> value

语法8:db.collection.find({ “key” : { $mod : [ 10 , 1 ] } }) 取模运算,条件相当于key % 10 == 1 即key除以10余数为1的

语法9:db.collection.find({ “key” : { $in: [ 1, 2, 3 ] } }) 属于,条件相当于key等于[ 1, 2, 3 ]中任何一个.

语法10:db.collection.find({ “key” : { $nin: [ 1, 2, 3 ] } }) 不属于,条件相当于key的值不属于[ 1, 2, 3 ]中任何一个。

语法11:db.collection.find({ “key” : { $size: 1 } }) $size 数量、尺寸,条件相当于key对应的值的数量是1(值必须是数组)

语法12:db.collection.find({ “key” : { $exists : true|false } })

语法13:db.collection.find({ $or : [{a : 1}, {b : 2} ] })

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值