就一数据库,掌握基本用法,其他的现学现卖就行了.

所以要把握基本套路.

创建数据库=>使用数据库=>创建集合=>使用集合=>创建文档=>使用文档

1.数据库

mongodb和mysql目前我发现了一个比较明显的区别是:

  mysql要想使用一个数据库,必须先创建一个数据库,而mongodb是直到你真正想某个数据库写入才会生成这个数据库.

数据库基本操作无非那么几个:

创建数据库:

如上所述,不存在的,简单的:use dbname

查看数据库都那些:show dbs

删除数据库:

db.dropDatabase()

总结,操作数据库:[创建数据库]=>选择数据库(use)=>删除数据库(db.dropDatabase())

实验证明,如果没有use直接删库,不会删除任何数据库.

2.数据集合

创建:

db.createCollection(collectionName,createOption)

createOption是一个词典,里面可以有4个键值对:capped(固定大小的集合),autoIndexId(真假),size(集合最大值,字节为单位),max(最大文档值)

例如,创建一个autoIndexId,无固定大小,无各种最大值的集合:

db.createCollection("collection1",{autoIndexId:true})

查看当前数据库集合状态:

show collections

删除数据库集合:

db.collectionName.drop()

3.数据行(文档)

创建|插入:

db.collectionName.insert(document)

如果插入多个文档呢???

db.collectionName.insertMany([document1,document2,...,documentn])

这里面所谓的document,实际是Binary JSON,即BSON,你可以单纯的看成是JSON,或者是Python的字典.

例如,文档格式有个字段,name,age,gender,profession,addr,tel.插入一个这样的信息,则可以写:

db.stu.insert({"name":"ZhangSan","age":22,"gender":"shemale","profession":"chairmanOfSchool","addr":"HeiLongJiang","tel":17777777777"})

MongoDB到目前为止,除了插入文档是必要之外,创建各种库,集合都是可以省略的...

由于MongoDB相对宽松的规则,所以,还可以使用save去插入|更新一些信息,核心就是保存之前不存在的当然就是插入了,保存之前有的就是更新了.用法:

db.collectionName.save(document)

查看集合中的所有文档:

db.stu.find()

删除:

db.collectionName.remove(<query>,{justOne: <boolean>,writeConcern: <document>})

参数全部可选.

删除多个:

db.collectionName.deleteMany({ "name":"ZhangSan" })

更新:

db.collectionName.update(<query>,<update>,{upsert,multi,writeConcern})

其中,后三个都为可选.upsert==update insert.writeConcern(报错级别)

例如:

db.stu.update({"tel":17777777777"},{$set:{"tel":"1"}})

如果更改某一列(字段),

db.stu.update({"tel":17777777777"},{$set:{"tel":"1"}},{multi:true})

只更新第一条记录:

db.collectionName.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } );

全部更新:

db.collectionName.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true );

只添加第一条:

db.collectionName.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false );

全部添加加进去:

db.collectionName.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true );

全部更新:

db.collectionName.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );

只更新第一条记录:

db.collectionName.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );

查询:

db.collectionName.find(<query>,projection)

其中,projection是可以包含或排除的一些返回结果,所以,例如:

db.collectionName.find({"addr":HeliLongJiang"},{addr:true})

OR:

db.collectionName.find({$or:[{key1:value1},{key2:value2}]})

返回指定字段:

db.CollectionName.find({},{addr:true})

4.数据字段(列)

5.数据索引(下标)

6.数据主键(标识作用的字段)

mongodb4简明笔记的更多相关文章

  1. Git & Github 一页简明笔记

    由于小组工程需要使用git&github的版本控制来协作,但我对其使用并不熟悉,特此写篇一页的笔记放在手边,备随时查阅. 相信这种一页的简明笔记,对大家也是有帮助的.我的笔记总结自廖雪峰的Gi ...

  2. sc7731 Android 5.1 LCD驱动简明笔记之三

    此篇笔记基于sc7731 - android 5.1,对lcd的gralloc库做一个简明笔记. 第一部分 调用gralloc.sc8830.so所谓的Gralloc模块,它就是一个模块,一个操作ke ...

  3. sc7731 Android 5.1 LCD驱动简明笔记之二

    此篇笔记基于sc7731 - android 5.1,对lcd的framebuffer做一个简明笔记. 一共分为两大部分:第一部分,关于LCD的硬件方面的:第二部分,关于lcd核心处理(framebu ...

  4. 【python】命令行神器 Click 简明笔记

    全文拷贝自 命令行神器 Click 简明笔记 Click Click 是用 Python 写的一个第三方模块,用于快速创建命令行.我们知道,Python 内置了一个 Argparse 的标准库用于创建 ...

  5. HTTP2.0 简明笔记

    前言 RFC2616发布以来,一直是互联网发展的基石.HTTP协议也成为了可以在任何领域使用的核心协议,基于这个协议人们设计和部署了越来越多的应用.HTTP的简单本质是其快速发展的关键,但随着越来越多 ...

  6. nginx rewrite重写规则简明笔记

    nginx rewrite重写规则简明笔记 比方说http://newmiracle.cn/?p=888我要改成能这个访问http://newmiracle.cn/p888/ 首先用正则获取888 ^ ...

  7. 35-less 简明笔记

    分屏显示文本文件 less [options] [file-list] less与more类似,但比more更加完善 例如:在显示一屏文本之后,less将显示提示副等待下一条命令的输入;可以向前或向后 ...

  8. 异步任务神器 Celery 简明笔记

    转自:http://www.jianshu.com/p/1840035cb510 异步任务 异步任务是web开发中一个很常见的方法.对于一些耗时耗资源的操作,往往从主应用中隔离,通过异步的方式执行.简 ...

  9. Git & Github 一页简明笔记(转)main

    由于小组工程需要使用git&github的版本控制来协作,但我对其使用并不熟悉,特此写篇一页的笔记放在手边,备随时查阅. 使用方法:常用命令供随时查阅,其余内容供新手了解. 0. 常用命令一览 ...

随机推荐

  1. AutoMapper 帮助类

    AutoMapper帮助类 /// <summary> /// AutoMapper帮助类 /// </summary> public static class AutoMap ...

  2. zabbix3.0通过yum安装笔记

    zabbix3.0通过yum安装笔记 一.通过yum安装zabbix rpm -Uvh https://repo.zabbix.com/zabbix/3.0/rhel/7/x86_64/zabbix- ...

  3. 解决win10安装MySQL数据库出现服务无法启动的问题

    安装mysql的时候一直出现这个问题,在网上找了很多种方法,终于解决了这个问题. 我在官网下载的安装包解压后没有my.ini文件,需要自己添加(红字不要复制) [mysql]# 设置mysql客户端默 ...

  4. C语言入门学习和整理 1-3

    1. int main() { char c = 'A'; printf("c=%c", c); } int main() { ; printf("c=%c", ...

  5. 1、win10下的Docker+Redis 的下载及简单使用

    一.下载Docker: 因为始终注册docker账号不成功,所以在这里点击下载. 选中docker-for-windows/ 选中beta/ 下载这个.msi文件 二.安装 1.安装.msi文件,桌面 ...

  6. Delphi XE7调用Java Class,JAR

    Delphi XE5,XE6需要用户手工编译并将Classes.Dex加入到包中,不过Delphi XE7可以省掉这些工作了. 如何在XE7中调用Java,具体步骤如下: 1.将jar文件添加到XE7 ...

  7. 【转载++】fopen返回0(空指针NULL)且GetLastError是0

    结论来看,是一个简单又朴素的道理——打开文件句柄用完了得给关上.表现在现象上却是着实让人费解,以至于有人还怀疑起了微软的Winodws系统来了,可笑至极.还是那句话,先把自己的屁股先给擦干净喽再怀疑别 ...

  8. SOC中的DFT和BIST对比与比较-IC学习笔记(二)

    ATE:ATE是Automatic Test Equipment的缩写,根据客户的测试要求.图纸及参考方案,采用MCU.PLC.PC基于VB.VC开发平台,利用TestStand&LabVIE ...

  9. Redis数据结构总结

    Redis 字符串(String) SET runoobkey redis GET runoobkey Redis 哈希(Hash) Redis hash 是一个string类型的field和valu ...

  10. day4 基础

    1.变量 2.打印名片 3.raw_input() 和 input() 4.变量类型 type 5. if-else 6.标示符的规则 7.关键字 8.运算符 9.print打印多个值 1.变量 sc ...