一、mongoDB介绍和使用

  1、分布式文件储存数据库,使用C++开发的,可以存储任意数据(文件),允许在服务器端执行脚本,使用JSON形式储存数据{key:value}

  2、支持的编程语言有:PHP 、ruby、python、C++、C#、Java等等

  3、使用db表示当前数据库

  4、安装:apt install mongodb / 源码安装

  5、运行:mongo     启用端口 27017

  6、管理工具:NoSQL Manager for MongoDB 、Navicat

  7、https://www.cnblogs.com/phpper/p/9196870.html     windows 系统上PHP7安装mongodb 扩展

二、MongoDB中的一些概念:

  database   数据库

  collection    数据集合(表)

  document     文档(行)

  field        域(字段)

  index   索引

  不支持 表连接

  数据库 ----> 集合----> 文档----> 域

  MongoDB 中可以有多个数据库,不同的数据库可以放置在不同的文件中

  系统数据库:

    admin:相当于root数据库,该数据库是一个高权限的数据库,在该数据库中可以执行全部的命令

    local:存储本地服务器的集合

    config:与数据库的分片有关

三、常用命令:

  show dbs   查看所有数据库

  use admin   切换数据库

  db    当前数据库

  use 数据库名    创建数据库

  db.dropDatabase()     删除当前使用的数据库

  db.createCollection(‘集合名’)    创建集合

  db.集合名.drop()   删除集合   返回值是布尔

  show collections   查看集合

  db.集合名.insert({key1:value1,key2:value2})    创建文档 ,k1和k2是域,v1和v2是域对应的值,域可以不加单双引号

  db.users.find().pretty()   (可读性高)查看users集合下的所有文档

  db.集合名.remove({})   删除文档

  db.集合名.update({被更新的对象},{$set:{更新的内容}})    更新文档,默认只更新第一条发现的数据

    全部更新:db.集合名.update({被更新的对象},{$set:{更新的内容}},{muti:ture})

四、查询数据-条件

  $lt => <      $lte =>  <=       $gt =>  >     $gte => >=     $ne =>  !=     $regex  正则    :  =>  =

  等于:{k:v}

  小于:{k:{$lt:v}}     {id:{$lt:20}} :id小于20的

  大于:{k:{$gt:v}}

  小于等于:{k:{$lte:v}}

  大于等于:{k:{$gte:v}}

  不等于:{k:{$ne:v}}

  多条件使用,隔开  db.集合.find({},{})   多条件是与的关系

  或的关系 db.集合名.find({$or:[{},{}]})

  限制查询的结果:db.集合名.find({k1:v1,k2:v2}).limit(数字)

  跳过前几个来显示查询:db.集合名.find({k1:v1,k2:v2}).skip(1)   跳过第一列

  排序:db.集合名.find({k1:v1,k2:v2}).sort({k:1})    升序

     db.集合名.find({k1:v1,k2:v2}).sort({k:-1})    降序

五、数据类型

  布尔

  数字

  字符

  浮点数

  数组

  内嵌文档

  null

  

NOSQL基础的更多相关文章

  1. NoSQL基础学习

    NoSQL基础学习 最近学习的第一个Nosql就是Mongodb,为了了解Nosql的基本知识,特地总结,主要是学习Nosql的理论 一.Introduction(介绍) 它是“ Not Only S ...

  2. NOSQL基础概念

    NoSql是一个很老的概念了,但对自己来说,仍然是一个短板,果断补上. 首先通过几个简单的例子来了解NOSQL在国内的情况(2013年左右的数据,有些过时),比如新浪微博,其就有200多台物理机运行着 ...

  3. NoSql基础知识

    一.为什么要有NoSql 关系型数据库在三个方面存在不足,或者说,比不上NoSQL: 1.大量数据的写入处理 这里说的关系型数据库不擅长大量数据写入,并不是说关系型数据库在进行大批量数据插入的时候,比 ...

  4. 具体解释NoSQL数据库使用实例

    一.NoSQL基础知识 1.关于NoSQL 在"NoSQL"一词.实际上是一个叫Racker的同事创造的,当约翰埃文斯埃里克要组织一次活动来讨论开源的分布式数据库. 这个名称和概念 ...

  5. 关于Mongodb的全面总结

    MongoDB的内部构造<MongoDB The Definitive Guide> MongoDB的官方文档基本是how to do的介绍,而关于how it worked却少之又少,本 ...

  6. Redis学习笔记(1)

    一.NoSQL基础知识 1. NoSQL概念 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库.随着互联网web2.0网站的兴起,传统的关系数据库 ...

  7. NOSQL学习笔记系列之MongoDB 一 基础

    主题:MongoDB 学习资料参考网址: 1.http://www.w3cschool.cc/mongodb/mongodb-tutorial.html 2.http://www.icoolxue.c ...

  8. NoSQL之基础篇

    NoSQL(NoSQL = Not Only SQL ),泛指非关系型的数据库.随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2. ...

  9. [转载]NoSQL数据库的基础知识

    关系型数据库和NoSQL数据库 什么是NoSQL 大家有没有听说过“NoSQL”呢?近年,这个词极受关注.看到“NoSQL”这个词,大家可能会误以为是“No!SQL”的缩写,并深感愤怒:“SQL怎么会 ...

随机推荐

  1. APP自动化 -- 获取toast元素的文本内容

    一.toast元素 1.表现形式:toast元素就是下图中  “操作成功” 那个一闪而过的标签. 2.特殊点:因为一闪而过,时间太短,用UIAutomatorView截屏截不到. 二.获取方法 1.用 ...

  2. Learning in the Frequency Domain 解读

    论文:Learning in the Frequency Domain, CVPR 2020 代码:https://github.com/calmevtime/DCTNet 实际的图像尺寸比较大,无法 ...

  3. eclipse IDE usage of my own and tutorials link list

    设置 字符集 Eclipse 修改字符集 默认情况下 Eclipse 字符集为 GBK,但现在很多项目采用的是 UTF-8,这是我们就需要设置我们的 Eclipse 开发环境字符集为 UTF-8, 设 ...

  4. Java-旋转字符串

    描述 旋转字符串 给定一个字符串(以字符数组的形式给出)和一个偏移量,根据偏移量原地旋转字符串(从左向右旋转). 挑战 在数组上原地旋转,使用O(1)的额外空间 说明 原地旋转意味着你要在s本身进行修 ...

  5. numpy巩固

    导包 import numpy as np 创建二维数组 x = np.matrix([[1,2,3],[4,5,6]]) 创建一维数组 y = np.matrix([1,2,3,4,5,6]) x ...

  6. PHP stripos() 函数

    实例 查找 "php" 在字符串中第一次出现的位置: <?php高佣联盟 www.cgewang.comecho stripos("I love php, I lo ...

  7. Idea快捷生成serialVersionUID

    Java对象实现了Serializable接口,是需要创建serialVersionUID,避免此对象在序列化.反序列化时出现问题.但idea默认没有生成serialVersionUID的设置,需要手 ...

  8. HashMap:从源码分析到面试题

    1 HashMap简介 HashMap是实现map接口的一个重要实现类,在我们无论是日常还是面试,以及工作中都是一个经常用到角色.它的结构如下: 它的底层是用我们的哈希表和红黑树组成的.所以我们在学习 ...

  9. MySQL时间设计 int timestamp datatime 查询效率性能比较

    在数据库设计的时候,我们经常会需要设计时间字段,在MYSQL中,时间字段可以使用int.timestamp.datetime三种类型来存储,那么这三种类型哪一种用来存储时间性能比较高,效率好呢?飘易就 ...

  10. 【av68676164(p55-p58)】 Intel CPU和Linux内存管理

    7.4.1 Intel CPU物理结构 https://www.cnblogs.com/megachen/p/9768115.html x86实模式 实模式 20位:1M内存空间 地址表示方式:段地址 ...