Mongodb与关系型数据库最大的区别就是无约束, 既无字段(外键等)约束, 也没有数据类型约束, 以json存储

安装
  启动Mongodb(默认在c盘找 data/db/文件夹)
  服务端:
    mongod --dbpath "指定数据库目录"
  默认端口 27017
  客户端:
    mongo

常用命令:

  show dbs
    查看所有存在磁盘上的数据库

  show tables
    查看当前数据库存在磁盘上的表(collections)

  use db
    创建(不存在这个名字) 或者 切换数据库

  db
    当前数据库

  db.user(表名)
    创建表

  增
     db.user.insertOne({"name": "Amber"})
    db.user.insertMany([{"name": "May"}, {"name": "Ryan"])

  删
    db.user.deleteOne({"name": "Amber"})
    db.user.deleteMany([{"name": "May"}, {"name": "Ryan"])

  改
    updata 需要结束一下修改器
    ({"条件"},{"关键字(修改器)":{"修改内容"}})

    $set 修改, 没有则添加一个字段
    db.user.updataOne({'name': 'Ryan'}, {$set: {'age': 18}})

    $unset 删除Field
    db.user.updataOne({'name': 'Ryan'}, {$unset: {'age': 1}})

    $inc 将查询到的某个结果,加上一个某个值
    db.user.updateOne({'name': 'Ryan'}, {$inc: {'age': -10}})

    array 修改器

    $push 在array(list)尾端添加一个新元素
      db.user.updateOne({'name': 'Ryan'}, {$push: {'hobby': '喝酒'}})

    $pull 删除某一个元素
      db.user.updateOne({'name': 'Ryan'}, {$pull: {'hobby': '做梦'}})

    $pop 删除 1是倒数第一个, -1 是正数第一个
      db.user.updateOne({'name': 'Ryan'}, {$pull: {'hobby': 1}})

    $pushAll
      db.user.updateOne({'name': 'Ryan'}, {$pushAll: {'hobby': ['爬山', , '游泳']}})

    $ 代指符 $存储符合条件的元素下标(索引)

      Array中的Object
          "hobby" : [
          "喝酒",
          {
             "name" : "ball",
             "price" : 100
          },
          "爬山",
          "游泳"
          如果要修改 ball 的价格 200
              db.user.updateOne({'hobby.name': 'ball'}, {$set: {'hobby.$.price': 200}})

    Object中的Array
      {
        "info" : {
           "id" : 1,
           "name" : "Ryan",
           "age" : 73,
           "hobby" : [
              "喝酒",
              "爬山"
              ]
            }
          }
      把喝酒改成游泳
         db.user.updataOne({'info.hobby': '喝酒'}, {$set: {'info.hobby.$': '游泳'}})

  查
    db.user.find({条件})

    且
      db.user.find({{"id":2,"age":18}})

    或
      db.user.find({$or: [{'age': {$gt: 18}}, {'name': 'May'}]})

    in
      db.user.find({'age': {$in: [10, 20, 30]}})

  sort, skip, limit:
    skip(5) 跳过五条数据
    limit(5) 只显示五条数据

    sort({age:1}) 升序
    sort({age:-1}) 降序

    如果三个关键字同时出现,优先级如下
    1.sort 2.skip 3.limit
      db.user.find().sort({'field': 1 or -1}).skip(n).limit(n)

pymongo
  注意:
    '_id': ObjectId('5c3eddb16c347e190d0510cc' 是ObjectId类的对象
    如果要序列化,也先str(_id),强转字符串在序列化

mongodb基础语法的更多相关文章

  1. mongodb 基础语法

    参考原文:菜鸟教程 目录 一.数据库二.文档三.索引四.聚合 一.数据库 show dbs -- 查看所有数据库 use DATABASE_NAME -- 如果数据库不存在,则创建数据库,否则切换到指 ...

  2. 2019-10-30:渗透测试,基础学习,mssql堆叠内联注入,mongodb基础语法

    使用xp_cmdshell需要堆叠注入,http://192.168.190.148/less-1.asp?id=1';EXEC sp_configure 'show advanced options ...

  3. MongoDB基础知识 02

    MongoDB基础知识 02 6 数据类型 6.1 null : 表示空值或者不存在的字段 {"x":null} 6.2 布尔型 : 布尔类型只有两个值true和false {&q ...

  4. MongoDB基础知识 01

    MongoDB基础知识  1. 文档  文档是MongoDB中的数据的基本单元,类似于关系型数据库管理系统的行. 文档是键值对的一个有序集.通常包含一个或者多个键值对. 例如: {”greeting& ...

  5. MongoDB 基础(2019年开篇)

    MongoDB基础知识: 1.什么是MongoDB NoSQL(NoSQL=Not Only SQL),意即"不仅仅是SQL". MongoDB是一个介于关系数据库和非关系数据库之 ...

  6. Hive学习笔记:基础语法

    Hive基础语法 1.创建表 – 用户表 CREATE [EXTERNAL外部表] TABLE [IF NOT EXISTS 是否存在] HUserInfo ( userid int comment ...

  7. MongoDB基础教程[菜鸟教程整理]

    MongoDB基础教程 ======================================================================================== ...

  8. 分布式文档存储数据库之MongoDB基础入门

    一.MongoDB简介 MongoDB是用c++语言开发的一款易扩展,易伸缩,高性能,开源的,schema free 的基于文档的nosql数据库:所谓nosql是指不仅仅是sql的意思,它拥有部分s ...

  9. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

随机推荐

  1. ClamAV病毒软件的安装和使用

    ClamAV 杀毒是Linux平台最受欢迎的杀毒软件,ClamAV属于免费开源产品,支持多种平台,如:Linux/Unix.MAC OS X.Windows.OpenVMS.ClamAV是基于病毒扫描 ...

  2. Vim 的 Python 编辑器详细配置过程 (Based on Ubuntu 12.04 LTS)

    为什么要用vim编辑py文件? 因为在Linux命令行中,缺少图形界面的IDE,vim是最佳的文本编辑器,而为了更好的编辑py文本,所以配置vim. 1. 安装完整版vim vi和vim的区别? 在L ...

  3. RabbitMQ之总结

    P:生成者,消息产生者: C:消息消费者: 红:消息队列: java实现 步骤: 创建连接 从连接中创建通道(相当于JDBC中的Statement) 通过channel声明(创建)队列.(如果队列存在 ...

  4. Java的Integer和int有什么区别

    Java是面向对象的编程语言,一切都是对象,但是为了编程的方便还是引入了基本数据类型,为了能够将这些基本数据类型当成对象操作,Java为每一个基本数据类型都引入了对应的包装类型(wrapper cla ...

  5. codeforces水题100道 第二十六题 Codeforces Beta Round #95 (Div. 2) A. cAPS lOCK (strings)

    题目链接:http://www.codeforces.com/problemset/problem/131/A题意:字符串大小写转换.C++代码: #include <cstdio> #i ...

  6. nodelua

    最近在学习go,对go中网络处理的方式比较喜欢,就用lua coroutine + C 模仿着接口实现一个玩具玩玩. 主要框架是lua导入C模块的时候会启动一个网络线程,lua和网络之间通过两个消息队 ...

  7. 美秒快报 移动端API接口后台制作总结

    1.创建方法时,不要用index这类的不易显示该方法功能的单词,尽量使用功能的缩写 例如: public function xssc(){} 2.尽量少用Request方法,多用input助手方法获取 ...

  8. PKI技术原理

    转:http://3layer.blog.51cto.com/57448/20430 对称加密         symmetric cryptographic 非对称加密     asymmetric ...

  9. javaweb基础 01--JSP取得绝对路径应用

    1.相关函数说明 * request.getScheme() 等到的是协议名称,默认是http * request.getServerName() 得到的是在服务器的配置文件中配置的服务器名称 比如: ...

  10. 九度OJ小结2

    由于安排问题,距离上次小结时间已经过去很久.导致这次小结的内容很多. 本次小结涉及到主要内容如下所示: 基于并查集操作的最小生成树问题(prime算法或者kruskal算法): 最短路径问题(Floy ...