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