MongoDB的安装和使用

一、Mongo的安装和使用
先下载安装Mongo到官网下载对应的32为的版本 然后安装
找到官网的下载中心
https://www.mongodb.com/download-center#community
找到 Previous Releases
找到对应window Vista 32-bit withoutSSL i386
注意:32-bit builds are limited to around 2GB of data. In general you should use the 64 bit builds. See here for more information.

在C盘目录下面建立data目录
data目录下面建立db和log: 2个目录----目录一定要先创建
注意实际安装测试时需要建立2个对应的目录结构

1.windows32位系统组装安装自启动代码
以管理员的方式运行下面的命令
如果安装失败可以查看日志信息 查看安装的错误信息
mongod --dbpath="C:\data\db" --logpath="C:\data\log\log.txt" --serviceName MongoDB --journal --storageEngine=mmapv1 --install

注意:以管理员方式启动
/*
--dapath 指定数据的文件存储路径
--logpath 数据的操作日志
--serviceName 服务名称 建议MongoDB
--serviceDisplayName window组件的显示名称 可以跟服务名称不一致
指定在32位下面的存储格式
--journal --storageEngine=mmapv1 --install

卸载:
mongod --remove --serviceName "H512MongoDB" --journal
*/
mongod --dbpath="C:\h512database\db" --logpath="C:\h512database\log\log.txt" --serviceName H512MongoDB --serviceDisplayName H512MongoDB --journal --storageEngine=mmapv1 --install
// 32位系统 必须设置存储格式为 mmapv1
// 63位系统 不需要设置

64位安装
mongod --dbpath="C:\Program Files\MongoDB\data\db" --logpath="C:\Program Files\MongoDB\data\db\log.txt" --serviceName MongoDB

2.然后启动
必须在管理员的权限下启动
net start MongoDB

net stop MongoDB

3.删除对应的服务 修改最后一个为--remove就可以了
mongod --dbpath="C:\data\db" --logpath="C:\data\log\log.txt" --serviceName MongoDB --journal --storageEngine=mmapv1 --remove

4.输入mongo(数据库的连接工具) 连接Mongo数据库查看能否连接成功

show dbs //查看对应的所有的数据库
use admin //客户端 客户端 手动关闭数据库
db.shutdownServer();

二 、Mongo的基本使用
Mongo的介绍 NOSQL数据库类型
show dbs // 查看已经存在的集合数据

db.help() // 查看数据库的所有相关的方法

db.stats() // 查看数据库的状态

db.version() // 查看当前db的版本

db.getMongo() // 查看当前db的链接地址

use blog // 先切换到对应的数据集合类
// 切换数据库
// 数据库有多个 每次只能操作一个数据库
// 数据库里面的是集合 理解为表

show collections // 查看集合中的所有的数据信息

db.users.insert({"book_id":1});

db.users.find().count();

db.users.find({"book_id":1});

//这个主键的id 是自动生成的数据

db.users.find({"_id":ObjectId("58bcd55fbcbc58571cb74cd6")});

db.userInfo.find({name: /mongo/});

//相当于%%select * from userInfo where name like ‘%mongo%’;

db.userInfo.find({name: /^mongo/});

//select * from userInfo where name like ‘mongo%’;

// update 第一个是条件 第二个是要修改的值
db.users.update({"book_id":1},{$set:{"book_id":8}});

//执行后显示: WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

db.users.update({"book_id":1},{$set:{"book_di":10}},{"multi":true});

// 注意update 和 save的区别
update有3个参数
save方法只有一个参数 并且 如果更新的键没有 则会替换整个字段 会丢失一些字段信息
db.user.save({"_id":ObjectId("58bce7acbcbc58571cb74cd9"),"book_name":"ios"});

// 删除 remove方法只有一个条件
db.user.insert({"username":"david"});
db.user.insert({"username":"david"});
db.user.insert({"username":"david"});

先执行前面的插入3条数据 然后在执行后面的删除 删除前面插入的3条数据信息

db.user.remove({"username":"david"});

// 第2个参数默认为false 如果设置为true 则只删除 查询到的第一条记录信息
// 第2个参数 表示是否是单行删除 默认为false 表示不是单行删除
db.user.remove({"username":"david"},true);

/*
find:查询到的集合信息
{ "_id" : ObjectId("58bce5e3bcbc58571cb74cd8"), "book_id" : 999, "book_name" : "html5" }
{ "_id" : ObjectId("58bce7acbcbc58571cb74cd9"), "book_name" : "ios" }
{ "_id" : ObjectId("58bceadfbcbc58571cb74cde"), "username" : "david" }
{ "_id" : ObjectId("58bceadfbcbc58571cb74cdf"), "username" : "david" }
{ "_id" : ObjectId("58bceae1bcbc58571cb74ce0"), "username" : "david" }
*/

// 空条件 表示删除集合中所有的元素信息
// 类似清空表中的数据 但是表不删除 mongodb中叫索引(即表索引)不删除
db.user.remove({});

// 删除整个集合 类似删除表的操作
// 删除整个文档 和 文档对应的索引 即表名称
db.user.drop();

db.dropDatabase(); 删除当前所在的数据库信息

Mac下面 mongo命令行窗口中 输入cls 清除屏幕的信息

// 全部替换为后面的值
db.testuser.update({username:"tom"},{"username":"jack","age":20,sex:1});

// 设置数据字段中的属性值 自增显示
db.testuser.update({"username":"tom"},{$inc:{age:1}});

// 删除某个字段
db.testuser.update({username:"tom"},{$unset:{sex:1}});

// 可以向记录中添加或修改 一个值 不存在就添加 存在就修改
db.testuser.update({username:"jack"},{$set:{like:[]}});

// pull 向数组中删除一条记录

db.testuser.update({"username":"jack"},{"$pull":{like:["develpment"]}})

// push 向数组中添加一条记录
db.testuser.update({"username":"jack"},{"$push":{like:["develpment"]}})

// push 向数组中添加多条信息
db.testuser.update({"username":"jack"},{$pushAll:{like:["sport","computer"]}})

// 删除数组中的最后一个值
db.testuser.update({"username":"jack"},{$pop:{like:1}})

// 删除数组中的第一个值
db.testuser.update({"username":"jack"},{$pop:{like:-1}})

db.testuser.remove({});

db.testuser.remove({username:"david"});

db.testuser.drop();

三、数据库的备份和恢复

// 从制度的位置恢复数据库
mongodump -d blog -o /testData

mongorestore -d blogtest /testData/blog

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容