mongodb学习01介绍
安装/运行
- 查看当前mongodb运行情况:
pgrep mongo
; - 在当前路径下建立数据库:
mkdir -p data/db
- 按照一个数据库路径运行
mongod --dbpath ./data/db
- 运行数据库之后,使用
mongo
; 然后可以进行数据库/表单操作
基本命令
- 成功启动MongoDB后,再打开一个命令行窗口输入
mongo
,就可以进行数据库的一些操作。 show dbs
:显示数据库列表show collections
:显示当前数据库中的集合show users
:显示用户use <db name>
:切换当前数据库db.foo.find()
: foo指的是当前数据库下,一个叫foo的集合(表);对于当前数据库中的foo集合进行数据查找(由于没有条件,会列出所有数据)db.foo.find( { a : 1 } )
:对于当前数据库中的foo集合进行查找,条件是数据中有一个属性叫a,且a的值为1
常用命令
help
db.help()
db.foo.help()
db.foo.find().help()
rs.help()
数据表
- 到某个数据库之后执行
db.createCollection("Account")
或者db.createCollection("Test",{capped:true, size:10000})
capped:true,表示该集合的结构不能被修改;
- size:在建表之初就指定一定的空间大小,接下来的插入操作会不断地按顺序APPEND数据在这个预分配好空间的文件中,如果已经超出空间大小,则回到文件头覆盖原来的数据继续插入。这种结构保证了插入和查询的高效性,它不允许删除单个记录,更新的也有限制:不能超过原有记录的大小。这种表效率很高,它适用于一些暂时保存数据的场合,比如网站中登录用户的session信息,又比如一些程序的监控日志,都是属于过了一定的时间就可以被覆盖的数据。
- 修改数据表名:
db.Account.renameCollection("Account1")
数据库
- 查看当前使用的数据库:
db.getName()
或者db
- 删除当前使用数据库:
db.dropDatabase()
; - 切换数据库:
use <otherdb>
- 创建数据库: 先
use <newdb>
,然后db.createCollection('user')
, 这样就创建来数据库和一个数据表 - 查看数据库结构:
db.status()
- 查看数据库版本:
db.version()
数据库其他操作
- 查看当前db的链接机器地址:
db.getMongo()
; - 从指定主机上克隆数据库:
db.cloneDatabase(“127.0.0.1”)
; 将指定机器上的数据库的数据克隆到当前数据库 - 从指定的机器上复制指定数据库数据到某个数据库:
db.copyDatabase("mydb", "temp", "127.0.0.1")
;将本机的mydb的数据复制到temp数据库中 - 修复当前数据库:
db.repairDatabase()
; - 显示当前db所有聚集索引的状态:
db.printCollectionStats()
;
数据表增/改/删
- 添加
db.users.save({name: ‘test’, age: 23})
; - 避免空值: 例子:`db.users.save({email: {type: String, trim: true, unique: true, sparse: true}),`
- 修改:
db.users.update({age: 23}, {$set: {name: 'changeName'}}, false, true)
;相当于:update users set name = ‘changeName’ where age = 25;db.users.update({name: 'Lisi'}, {$inc: {age: 50}}, false, true)
;相当于:update users set age = age + 50 where name = ‘Lisi’;db.users.update({name: 'Lisi'}, {$inc: {age: 50}, $set: {name: 'hoho'}}, false, true);
相当于:update users set age = age + 50, name = ‘hoho’ where name = ‘Lisi’;
- 删除:
db.users.remove({age: 132})
;
简介
- 面向文档的数据库
- 以文档模型取代行的概念
- 不再有预定义模式,即文档的键和值不再是固定的类型和大小
- 支持存在时间有限的集合,适用于将在某个时刻过期的数据,如会话
- 不具备一些关系型数据库的普遍功能,如连接和复杂的多行任务
mongodb学习01介绍的更多相关文章
- Android Testing学习01 介绍 测试测什么 测试的类型
Android Testing学习01 介绍 测试测什么 测试的类型 Android 测试 测什么 1.Activity的生命周期事件 应该测试Activity的生命周期事件处理. 如果你的Activ ...
- Redis学习01——介绍与搭建环境
Redis学习01介绍与搭建环境一简介二yum配置已经配置了的可以跳过三安装gcc四安装redis1 上传Redis到linux中2 解压到usrlocal下3 编译redis4 安装redis5 拷 ...
- MongoDB学习笔记—Linux下搭建MongoDB环境
1.MongoDB简单说明 a MongoDB是由C++语言编写的一个基于分布式文件存储的开源数据库系统,它的目的在于为WEB应用提供可扩展的高性能数据存储解决方案. b MongoDB是一个介于关系 ...
- Mongodb学习笔记一(Mongodb环境配置)
Mongodb学习 说明: MongoDB由databases组成,database由collections组成,collection由documents组成,document由fileds组成.Mo ...
- MongoDB学习记录
一.操作符 "$lt" :"<""$lte" :"<=""$gt" :"> ...
- MongoDB学习:(一)MongoDB安装
MongoDB学习:(一)MongoDB安装 MongoDB介绍: 直接百科了: MongoDB安装: 1:下载安装: MongoDB安装:https://www.mongodb.com/do ...
- MongoDB学习(四)客户端工具备份数据库
在上一篇MongoDB学习(三)中讲解了如何在服务器端进行数据的导入导出与备份恢复,本篇介绍下如何利用客户端工具来进行远程服务器的数据备份到本地. 以客户端工具MongoVUE为例来进行讲解: 1.首 ...
- ThinkPhp学习01
原文:ThinkPhp学习01 一.ThinkPHP的介绍 MVC M - Model 模型 工作:负责数据的操作 V - View 视图(模板 ...
- MongoDB学习之--安全和认证
MongoDB学习之--安全和认证 本文主要介绍两部分内容,Mongodb的安全检查配置以及安全认证操作: 虽然确保系统安全是系统管理员的重要工作,但是作为程序员了解其机制也是大有好处的,毕竟不是每个 ...
随机推荐
- 【XLL API 函数】xlCoerce
将 XLOPER/XLOPER12 转换为另一种类型,或是查询表格中的单元格值. 函数原型 Excel12(xlCoerce, LPXLOPER12 pxRes, 2, LPXLOPER12 pxSo ...
- Linux内核补丁升级
如果机器已经联网,直接利用包管理工具更新,需要注意的是现在3.0以上的内核引入了签名机制,需要导入签名的key,参考步骤如下: 1.导入keyrpm --import https://www.elre ...
- IOS-Uikit框架介绍
•UIKit可识别三种类型的输入事件: –触摸事件 –运动(加速计)事件 –远程控制事件 IKit框架将触击信息封装为一个UIEvent对象,并派发给恰当的视图(有关UIKit如何将事件递送给您的视图 ...
- asp.net Excel数据导入到数据库中
protected void Btn_Import_Click(object sender, EventArgs e) { bool Result_Import = false; bool Resul ...
- 3ds max 分离对象
转换为可编辑面片,将编辑环境设置为以下状态: 选中所需面片,分离
- Linux Window Redis安装
Linux 下简易的安装过程: 1.源码安装之前要先安装gcc,不然编译会出错, 2.下载源码,去http://download.redis.io/releases/这个文件夹内找想安装的版本,我下载 ...
- ASP.NET Global 全局事件处理
添加Global文件,名字不要改 Global类说明: using System; using System.Collections.Generic; using System.IO; using S ...
- oracle dataguard (一)
一.什么是data guard及data guard的工作原理 Data Guard 是一个集合,由一个primary数据库(生产数据库)及一个或多个standby数据库(最多9个)组成.组成Data ...
- 解决IIS7、IIS7.5中时间格式显示的问题
今天在用IIS7的时候发现一个关于时间格式的问题,当我在ASP中使用now()时间函数的时候,日期是以"/"来分隔,而不是以"-"来分隔的,使得我在运行程序的时 ...
- 【转载】 Pyqt 利用QDataStream对文件进行存取
# -*- coding: utf-8 -*- from PyQt4.QtGui import * from PyQt4.QtCore import * import sys QTextCodec.s ...