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()
    
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

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