初窥 MongoDB
最近在研究Nodejs 自然就接触到了MongoDB 这玩意儿有意思 与关系型数据库相比少了很多条条框框 让我情不自禁的想要了解它的所有
MongoDB与Redis同类 属于NoSql的一种,特点是简单,方便扩展,性能更佳。
以下是MongoDB与MySQL的不同:
1.MongoDB事务稍弱(不支持多行多文档多语句原子性更新)
2.MongoDB不支持多表联查。
3.MongoDB没有表结构概念,每条记录可以存入完全不同的数据结构。
4.MongoDB完全的索引支持,这点比Redis纯键值对要强大,单键索引,多键索引,数组索引,全文索引,地图索引。
5.MongoDB速度快 性能优越 (默认操作是写日志 写内存 返回结果 然后才会在后台进行每隔几十毫秒的日志刷盘)
6.MongoDB的数据存储更加安全(默认支持三节点以上的复制集群)
(当然 肯定还有很多是我不知道的)
下载地址
https://www.mongodb.com/download-center#community
下载之后自行移动解压
本篇教程的解压后目录为 /usr/local/mongodb
手动创建配置文件
vim /usr/local/mongodb/mongodb.conf
配置文件写入以下内容:
#数据库存放目录
dbpath=/usr/local/mongodb/data
#是否启动日志
journal=true
#日志文件路径 非目录
logpath=/usr/local/mongodb/run.log
logappend=true
#绑定ip
bind_ip = 127.0.0.1
#绑定端口
port = 27018
#后台启动
fork = true
创建data目录与log文件
mkdir /usr/local/mongodb/data
touch /usr/local/mongodb/run.log
给个权限
chmod 755 -R /usr/local/mongodb
进入bin目录
cd /usr/local/mongodb/bin/
启动
./mongod -f /usr/local/mongodb/mongodb.conf
出现以下提示即为启动成功:
about to fork child process, waiting until server is ready for connections.
forked process: 16131
child process started successfully, parent exiting
连接数据库
./mongo
默认连接端口为27017 如果配置文件中指定了其他端口 则需要带上 如 ./mongo -port 27018
基本操作:
//查询所有库(空库不会显示)
show dbs
//查询所有表
db.getCollectionNames()
//切换数据库(如库不存在会自动创建)
use dbname
//往a表插入内容(如表不存在会自动创建)(MongoDB中的表 被称作为集合)
db.a.insert({username:'admin',password:123456})
//将a表中用户为admin的密码改为111111
db.a.update({'username':'admin'},{$set:{'password':111111}})
//删除a表中用户为admin的数据
db.a.remove({'username':'admin'})
查 与 MySQL对照
//所有的查询后面都可以跟上.pretty()代表格式化输出 如 db.a.find().pretty()
db.a.find() select * from a
db.a.count() select count(*) from a
db.a.findOne() select * from a limit 1
db.a.find({'username':'admin','password':123456}) select * from a where username='admin' and password=123456
db.a.find({'username':'admin'}, {password: 1}) select password from a where username='admin' //1为指定返回键 0为指定排除键
db.a.find({$or:[{"username":"admin"},{"username": "mongod"}]}) select * from a where username='admin' or username='mongod'
db.a.find({"num": {$gt:90}, $or: [{"username": "admin"},{"username": "mongod"}]}) select * from num>90 and (username='admin' or username='mongod')
db.a.find({"id" : {"$in" : [10, 11, 12]}}) select * from a where id in (10,11,12)
初窥 MongoDB的更多相关文章
- 初窥ElasticSearch
初窥ElasticSearch 官网上面的,不知道讲的是什么.. youtube上面有一个start with,内容是在windows以下跑这个elastic search,然后用一个fidler工具 ...
- Scrapy001-框架初窥
Scrapy001-框架初窥 @(Spider)[POSTS] 1.Scrapy简介 Scrapy是一个应用于抓取.提取.处理.存储等网站数据的框架(类似Django). 应用: 数据挖掘 信息处理 ...
- 初窥Kaggle竞赛
初窥Kaggle竞赛 原文地址: https://www.dataquest.io/mission/74/getting-started-with-kaggle 1: Kaggle竞赛 我们接下来将要 ...
- scrapy2_初窥Scrapy
递归知识:oop,xpath,jsp,items,pipline等专业网络知识,初级水平并不是很scrapy,可以从简单模块自己写. 初窥Scrapy Scrapy是一个为了爬取网站数据,提取结构性数 ...
- WWDC15 Session笔记 - Xcode 7 UI 测试初窥
https://onevcat.com/2015/09/ui-testing/ WWDC15 Session笔记 - Xcode 7 UI 测试初窥 Unit Test 在 iOS 开发中已经有足够多 ...
- Java发送邮件初窥
一.背景 最近朋友的公司有用到这个功能,之前对这一块也不是很熟悉,就和他一起解决出现的异常的同时,也初窥一下使用Apache Common Email组件进行邮件发送. 二.Java发送邮件的注意事项 ...
- 【软件工程】week5-个人作业-敏捷开发方法初窥
敏捷开发方法初窥 引言:本周的软件工程个人博客作业是阅读关于敏捷开发方法的文章(http://martinfowler.com/agile.html),并撰写自己的读后感.文章内容非常丰富,对敏捷开发 ...
- 网页3D效果库Three.js初窥
网页3D效果库Three.js初窥 背景 一直想研究下web页面的3D效果,最后选择了一个比较的成熟的框架Three.js下手 ThreeJs官网 ThreeJs-github; 接下来我会陆续翻译 ...
- iOS视频直播初窥:高仿<喵播APP>
视频直播初窥 视频直播,可以分为 采集,前处理,编码,传输, 服务器处理,解码,渲染 采集: iOS系统因为软硬件种类不多, 硬件适配性比较好, 所以比较简单. 而Android端市面上机型众多, 要 ...
随机推荐
- Hibernate 学习笔记 - 2
五.映射一对多关联关系 1. 单向多对一 即 单向 n-1 1)单向 n-1 关联只需从 n 的一端可以访问 1 的一端 ① 域模型: 从 Order 到 Customer 的多对一单向关联需要在Or ...
- 移动端自动化自动化(Android&iOS)——Appium
Appium-Python 移动端自动化环境搭建 Appium介绍 Appium是一个开源.跨平台的测试框架,可以用来测试原生及混合的移动端应用.Appium支持iOS.Android及Firefox ...
- 用javascript和html5做一个音乐播放器,附带源码
效果图: 实现的功能 1.首页 2.底部播放控件 3.播放页面 4.播放列表 5.排行榜 6.音乐搜索 输入搜索关键词,点击放大镜图标 7.侧边栏 目录结构 开发心得与总结 1.轮播图 首先感谢作者S ...
- C# 复制列表
本文:如何复制一个列表 最简单的方法是 foreach foreach(var temp in a) { b.Add(temp); } 有没一个简单的方法? using System.Linq; va ...
- Oracle学习笔记之游标详解
游标 游标存在意义:解决"select *"返回空.多行记录问题,但凡select,就可能多行结果集,也就需要用游标. 游标分4步走:cursor.open.fetch.close ...
- APP在模拟器崩溃,提示__gcd_queue_item_enqueue_hook_block_invoke
libBacktraceRecording.dylib`__gcd_queue_item_enqueue_hook_block_invoke: libBacktraceRecording.dylib` ...
- 超级简单的retrofit使用自签名证书进行HTTPS请求的教程
1. 前言 HTTPS越来越成为主流,谷歌从 2017 年起,Chrome 浏览器将也会把采用 HTTP 协议的网站标记为「不安全」网站:苹果从 2017 年 iOS App 将强制使用 HTTPS: ...
- 深入理解Java虚拟机--中
深入理解Java虚拟机--中 第6章 类文件结构 6.2 无关性的基石 无关性的基石:有许多可以运行在各种不同平台上的虚拟机,这些虚拟机都可以载入和执行同一种平台无关的字节码(ByteCode),从而 ...
- mysql用户权限设置,远程访问设置、设置固定ip远程访问,设置root用户不能远程访问mysql数据库
关于mysql的用户管理,笔记 1.创建新用户 通过root用户登录之后创建 >> grant all privileges on *.* to testuser@localhost ...
- swift 之 namespace
场景: 项目中类名过长,造成不能根据文件名区分出来,并且如果一个模块的类较多时,很难取一个比较优雅的名字.为了使模块名可读, 我们一般的做法就是添加模块前缀.但是如果模块中还有个子模块,如果还继续按 ...