mongodb初体验

在安装之前,我们首先了解一下mongo的常用功能

  • mongo 使用数据库
  • mongod 开机
  • mongoimport 导入数据库

1、1mac下mongodb的安装

  • 使用home-brew安装mongoldb
$ brew update
$ brew install mongodb
  • 修改环境变量
    把mongodb/bin加入$PATH ,以免我们每次输入sudo monogd ,变成直接monogd
$ touch .base_profile
$ vim .base_profile

加入path

export MONGO_PATH=/usr/local/mongodb
export PATH=$PATH:$MONGO_PATH/bin

1、2开机

  • 第一次开启mongod开机,一定要启动mmapv1存储引擎(这样做的目的,是为了在mongoVE中能看到我们的数据,而不是只在命令行中查看),命令如下;
mongod  --storageEngine mmapv1 --dbpath 任意存放数据的目录
  • 其他时间开机就不用启动上述的存储引擎了;只需要执行此命令:
mongod --dbpath /Users/zhanglei/Documents/mongoData

--dbpath 就是选择数据库文档所在的文件夹

  • 开机后如果想使用数据库,一定不能关机,得再开一个cmd;使用mongo命令链接数据库;连接成功以后,最后会显示27017,也就是端口号。
bogon:mongo_data wwr$ mongod  --storageEngine mmapv1 --dbpath /Users/wwr/Desktop/mongo_data
2017-09-29T11:30:35.846+0800 I CONTROL  [initandlisten] MongoDB starting : pid=7140 port=27017 dbpath=/Users/wwr/Desktop/mongo_data 64-bit host=bogon
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten] db version v3.4.9
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten] git version: 876ebee8c7dd0e2d992f36a848ff4dc50ee6603e
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten] OpenSSL version: OpenSSL 1.0.2l  25 May 2017
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten] allocator: system
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten] modules: none
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten] build environment:
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten]     distarch: x86_64
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten]     target_arch: x86_64
2017-09-29T11:30:35.847+0800 I CONTROL  [initandlisten] options: { storage: { dbPath: "/Users/wwr/Desktop/mongo_data", engine: "mmapv1" } }
2017-09-29T11:30:35.847+0800 E NETWORK  [initandlisten] listen(): bind() failed Address already in use for socket: 0.0.0.0:27017

此时,可以通过http访问该数据库,mongodb使用了27017端口,因此在浏览器中打开http://localhost:27017/。

(注:mongod.conf文件中bindIp: 127.0.0.1意思是本机访问,如果是外网访问需要重新设置)

1、3mongobd的常见命令

  • 查看有多少数据库:show dbs
  • 创建并切换到对应的数据库:use 数据库的名称
  • 查看数据库下有多少集合: show collections
  • 创建集合(在插入数据的时候,就自动创建了集合) db.集合名称.insert()
    - 插入的数据就是json类型; db.student.insert({"name":"xiaowang","age":8})
  • 查看当前集合下有多少数据:db.student.find();
  • 删除集合中的某条数据:
    db.student.remove({"name":"xiaowang"})
  • 删除集合中的所有数据(但是集合仍然存在):db.student.remove({})
  • 删除集合:db.集合名称.drop();
  • 查看自己当前所在的数据库:db
  • 删除数据库: db.dropDatabase()

1、4细说数据库命令

  • 批量导入:
    必须新开一个cmd;(cmd1:mongod; cmd2:mongo; cmd3:mongoimport)
    mongoimport --db 数据库名称 --collection 集合名称 --drop --file 指定文件的地址(这个文件一定得是个json文件);
db.student.insert({"name":"zhangsan"})
//指定删除对应的数据:如果遇到多个一样的,统统删除
db.restaurants.remove( { "borough": "Manhattan" } )
//删除一样的多个数据中的一条;
db.student.remove({"name":xxx},{justOne:true});
//删除当前集合下的所有数据;
db.restaurants.remove( { } )-》数据没了,但是集合还在
//删除集合
db.xxx.drop() ->集合没了
//第一个参数:查找; 第二个参数:修改;
db.student.update({"name":"xixi"},{$set:{"name":"haha"}});
//彻底覆盖;第二个对象,覆盖第一个对象;
db.student.update({},{})

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

推荐阅读更多精彩内容

  • NoSql数据库优缺点 在优势方面主要体现在下面几点: 简单的扩展 快速的读写 低廉的成本 灵活的数据模型 在不足...
    dreamer_lk阅读 2,698评论 0 6
  • MongoDB作为最流行的NoSQL数据库已经火了好几年了,可是一直没有时间尝试,正好我的项目里刚好有类似公告配置...
    xtg阅读 36,604评论 1 15
  • 上一篇分享了MongoDB的配置文件,现在准备正式在已有项目中使用,完成那个公告配置的需求。 整合Spring和M...
    xtg阅读 8,540评论 8 12
  • 我去了南方过冬。 与北国纯粹冰冷冬天相比,我选择了较温和湿润的南方过这个冬天,这种行为不被称为候鸟,因为我...
    千端阅读 230评论 1 2
  • 脾气有好坏吗?百度一下:相关搜索如下: 测试脾气好坏脾气好坏每个人都有他的脾气 一等人有本事没脾气 有本事的男人没...
    香杉阅读 529评论 2 1