美文网首页
mongodb初体验

mongodb初体验

作者: 蚊小文 | 来源:发表于2017-09-29 22:53 被阅读0次

    在安装之前,我们首先了解一下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()
      

    相关文章

      网友评论

          本文标题:mongodb初体验

          本文链接:https://www.haomeiwen.com/subject/lkvwextx.html