mongodb数据库的一些常用命令和基础知识

mongodb数据库的一些常用命令和基础知识

1、数据库分为两种,一为关系型数据库,代表为MySQL,一种是非关系型数据库,代表为mongodb。

  • 关系型数据库:Access mySql SqlServer oracle db2等。
  • 非关系型数据库:MongoDB,Redis,HBase,CouchDB等

2、二者区别:

在这里插入图片描述

  • 关系型数据库:以行和列的形式存储数据,以便于用户理解。这一系列的行和列被称为表,一组表组成了数据库。表与表之间的数据记录有关系。其最小的数据条目是 "行"
  • 非关系型数据库:以文档的形式存储数据,一系列的文档组成了集合,最小的数据条目是 “文档”
    - 非关系型数据库的数据存储结构是bson,bson是json的超集,在其基础上增加了二进制流。
    • 而图片、音频、视频都是以二进制的方式存储的
    • 基于分布式文件存储
    • 文档就是键值对的一个集合,实际上表达方式和json一样

3、mongodb的一些需要知道的小点:

  • MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
  • MongoDB 是非关系型数据库当中功能最丰富,最像关系型数据库的
  • MongoDB的一些优点:
    - 面向集合存储,易存储对象类型的数据
    • 模式自由
    • 支持动态查询
    • 支持完全索引,包含内部对象
    • 支持复制和故障恢复
    • 使用高效的二进制数据存储,包括大型对象(如视频等)
    • 自动处理碎片,以支持云计算层次的扩展性
    • 支持RUBY,PYTHON,JAVA,C++,PHP等多种语言
    • 文件存储格式为BSON(一种JSON的扩展)

4、bson存储格式

  • BSON是一种类似json的二进制形式的存储格式,简称Binary JSON,它和JSON一样,支持内嵌的文档对象数组对象,但是**BSON有JSON没有的一些数据类型,**如Date和BinData类型。

  • BSON可以做为网络数据交换的一种存储形式,这个有点类似于Google的Protocol Buffer,但是BSON是一种schema-less的存储形式,它的优点是灵活性高,但它的缺点是空间利用率不是很理想。

  • BSON有三个特点:轻量性、可遍历性、高效性。

5、mongodb数据库常用命令:

  • 数据库安装完毕且让其成为windows下可以使用后,
  • 先用 net start mongodb 来开启数据库服务,再键入mongo来链接服务,再后面就可以使用一些mongodb的操作命令了
  • 这个服务没有手动关闭,就一直开启着,有一定的内存消耗,如果要关闭,先要ctrl+c 或者exit退出,再net stop mongodb关闭服务
  • 下次再使用时,要先开启服务,再链接,再键入数据库命令操作即可
  • help:查看帮助命令
  • show dbs:显示各数据库
  • show collections:显示当前数据库的集合
  • use dbname:用来创建或使用数据库,如果这个数据库名称不存在,就是创建;已存在,就是操作这个数据库。一开始用这个来创建一个数据库时,只有继续向这个数据库里面添加数据才能保存,空数据库不会保存。

mongodb数据库之CURD(增删改查):

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

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

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

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

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

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

    db.web.save(_id:ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老王 " }) 会把 “老李” 改为 “ 老王” ,有update的作用。

2、数据库的删除:
  • 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没加双引号
3、数据库的修改
  • db.web.update({“name”:“a1”}, {$set: {sex:”women”}},true,true) 修改name=a1的数据为sex=1,第一个参数是查找条件,第二个参数是修改内容主键不能修改,第三个参数表示匹配所有符合条件的数据,第四个参数表示修改所有匹配到的数据
4、数据的查找:
  • db.users.find() 查找users集合中所有数据
  • db.users.findOne() 查找users集合中的第一条数据
  • db.users.find().pretty() 格式化查询到的数据

条件查找:

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

2、语法2: db.collection.find({ “key” : { $gt: value } }) 查找key > value的所有数据

3、语法3:db.collection.find({ “key” : { $lt: value } }) 查找key < value的所有数据

4、语法4:db.collection.find({ “key” : { $gte: value } }) 查找key >= value的所有数据

5、语法5:db.collection.find({ “key” : { $lte: value } }) 查找key <= value的所有数据

6、语法6:db.collection.find({ “key” : { $gte: value1 , $lte: value2 } }) value1 <= key <=value2

7、语法7:db.collection.find({ “key” : { $ne: value } }) key 不等于value的数据

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

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

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

排序:

1、db.collection.find().sort({ “key1” : -1 ,“key2” : 1 }) 这里的1代表升序,-1代表降序

其它:

1、db.collection.find().skip(2) 从索引是2的位置开始显示查找到的数据,即查找到的数据从第三条开始显示,3至以后。

2、db.collection.find().limit(2) 从索引是0开始显示查找到的数据,显示到第3位。1至3条。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值