mongoDB使用小记
1.简介:
MongoDB是由c++语言编写的,基于分布式文件存储的开源数据库系统。MongoDB将数据存储为一个文档,数据结构有键-值对,类似于JSON对象。
MongoDB其中的一些概念如下:

MongoDB中表相当于一个集合,行相当于一个文档,列相当于一个域。其中MongoDB自动将_id字段设置为主键。
2.安装与连接
(1)安装官网下载
(2)启动服务:

这里的路径可以自己设置,这是存储数据库数据的地方
启动成功后,流浪器访问localhost:27017,将会出现以下画面,27017为默认端口

(3) 连接

3.一些基础操作:
(1)show dbs
可以显示所有数据库
(2)db
显示当前数据库对象
(3)use <db>
使用指定的数据库
(4)show collections
查看当前表中所有集合
4.MongoDB数据类型

5.MongoDB创建数据库
use DATABASE_NAME
当DATABASE_NAME不存在时会创建数据库,如果其存在则切换到指定数据库。
注意:当你新建的数据库内没有插入数据时,show dbs不会显示出你刚创建的数据库;
6.删除数据库
db.dropDatabase()
删除当前数据库。
7.创建集合:
集合相当于关系型数据库中表(table)的概念
db.createColection(name,options)
- name:要创建集合的名称
- options:可选的参数,可以是如下:

下面是一个例子:
创建一个固定集合my,整个集合空间的大小为6142800KB,文档中最大个数为10000个。
db.createCollection("my", { capped : true, autoIndexId : true, size :
6142800, max : 10000 } )
注意:当你在my集合中插入文档时,先检查是否满足size条件,再查看max条件,只有在两个都满足的前提下你才能插入文档
8.删除集合
db.collection.drop()
collection:指要删除的集合名称
9.插入文档
MongoDB使用insert()或者save()方法向集合中插入文档
db.COLLECTION_NAME.insert(document)
例子:

COLECTION_NAME是集合的名称,如果数据库中不存在该集合,那么MongoDB会自动创建该集合。
10.更新文档:
(1)update()方法用于更新已存在的文档。
db.collection.update(
<query>,
<update>,
{
upsert: <boolean>,
multi: <boolean>,
writeConcern: <document>
}
)
- query:update的查询条件,类似mysql的where条件语句
- update:update的对象和一些更新的操作符,可以理解为sql中set语句
- upsert:可选,表示如果不存在update的文档,是否插入新的文档,默认为false
- multi:可选,默认为false,表示只更新找到的第一条记录,如果为true则表示更新所有满足条件的文档
- writeConcern:可选,表示抛出异常的级别
实例:

(2)save()方法通过传入的文档替换已有的文档,语法格式为:
db.collection.save(
<document>,
{
writeConcern: <document>
}
)
document:新文档的数据.
其他实例:

11.删除文档
db.collection.remove(
<query>,
{
justOne: <boolean>,
writeConcern: <document>
}
)
实例:

12.查询文档
db.collection.find(query,projection)
query:可选,使用查询操作符指定查询的条件
projection:可选,使用投影操作符指定返回的键。查询是返回文档中所有键值
以易读的方式读取数据
db.collection.find().pretty()
看一下哪易读了:

一些常用的操作:

OR条件 {$or:[{key1:value1}, {key2:value2} ]}
学习笔记,参考http://www.runoob.com/mongodb
mongoDB使用小记的更多相关文章
- mongodb入门学习小记
Mongodb 简单入门(个人学习小记) 1.安装并注册成服务:(示例) E:\DevTools\mongodb3.2.6\bin>mongod.exe --bind_ip 127.0.0.1 ...
- MongoDB 小记
之前本人说过一款非关系型数据库的代表 Redis 的 < Redis 小记 >文章,觉得意犹未尽,今天就来介绍一款数据库 MongoDB ,先来看一下 MongoDB是一款基于分布式文件存 ...
- MongoDB小记
mongodb的一个简单使用. package com.chuntent.mongo; import java.util.Map; import java.util.Map.Entry; import ...
- Java程序中与MongoDB建立连接~小记
1.Mongo和MongoClient的关系 MongoClient继承自Mongo,使用Mongo也可建立连接,但是需要使用与Mongo适应的MongoOptions,MongoURI等类型. 2. ...
- 小记------mongodb数据库如何进行模糊查询
// 模糊匹配createTime 是以 2019-07-23 开头 db.getCollection('driver_online_record').find({"createTime ...
- linux 下cmake 编译 ,调用,调试 poco 1.6.0 小记
上篇文章 小记了: 关于 Poco::TCPServer框架 (windows 下使用的是 select模型) 学习笔记. http://www.cnblogs.com/bleachli/p/4352 ...
- MongoDB学习记录
一.操作符 "$lt" :"<""$lte" :"<=""$gt" :"> ...
- Java JPA小记
什么是JPA JPA之于ORM(持久层框架,如MyBatis.Hibernate等)正如JDBC之于数据库驱动. JDBC是Java语言定义的一套标准,规范了客户端程序访问关系数据库(如MySQL.O ...
- [转帖]「日常小记」linux中强大且常用命令:find、grep
「日常小记」linux中强大且常用命令:find.grep https://zhuanlan.zhihu.com/p/74379265 在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍 ...
随机推荐
- C++继承后的函数访问权限
今天在写代码时发现对继承后的函数访问权限不太清楚,于是自己做了个测试: 1.头文件(test.h) 1 #include <iostream> 2 using namespace std ...
- code1091 传染病控制
1.读入图,边是双向的 2.递归建树,同时确定每一层的节点 3.dfs按层搜索,先把这一层所有被传染的(die[pa[k]]=true的)的die置为true 然后循环,每次把一个die为true的变 ...
- catkin地址
Source: git https://github.com/ros/catkin.git (branch: kinetic-devel)
- HUST软工1501-1503班第2周作业成绩公布
说明 本次公布的成绩对应的作业为: 第2周个人作业:WordCount编码和测试 如果同学对作业成绩存在异议,在成绩公布的72小时内(截止日期4月26日0点)可以进行申诉,方式如下: 毕博平台的第二周 ...
- [GO]面向对象和面对过程的方式
package main import ( "fmt" ) //这里为面向过程的方式 func Add(a, b int) int { return a + b } //面向对象, ...
- css 字体上下居中显示 解决安卓手机line-height的偏差
1.字体左右居中显示 text-align: center <div class="font"> 上下居中 </div> .font{ width: ...
- CodeForces 288B Polo the Penguin and Houses (暴力或都快速幂)
题意:给定 n 和k,n 表示有n个房子,然后每个有一个编号,一只鹅要从一个房间中开始走,下一站就是房间的编号,现在要你求出有多少种方法编号并满足下面的要求: 1.如果从1-k房间开始走,一定能直到 ...
- element onclick 动态创建元素并绑定onclick事件
<html> <head> <meta charset="UTF-8"> <title>b</title> <sc ...
- 设计模式1---单例模式(Singleton pattern)
单例模式Singleton 面试的时候,问到许多年轻的Android开发他所会的设计模式是什么,基本上都会提到单例模式,但是对 单例模式也是一知半解,在Android开发中我们经常会运用单例模式,所以 ...
- TDE--相关Demo
SQL Server 2008引入透明数据加密(Transparent Data Encryption),它允许你完全无需修改应用程序代码而对整个数据库加密.当一个用户数据库可用且已启用TDE时,在写 ...