Mongodb的笔记(安装,Python操作,Robo3t操作)
2017-11-24 17:12
531 查看
安装Mongodb(Centos7)
官网上找到需要下载的版本压缩包进行下载。官网链接或者在命令行下使用
wget命令进行下载
# 这里下载的是3.4.10版本 wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.4.10.tgz[/code]
进行解压缩# 解压缩 tar -zxvf mongodb-linux-x86_64*.tgz # 重命名 mv mongodb-linux-x86_64* mongodb # 移动到你想放置的目录下,这里我放在/opt目录下 mv mongodb /opt/
进行相应的配置,mongodb默认没有任何配置# 进行mongodb主目录 cd /opt/ # 建立存放数据文件和日志文件的目录 mkdir -p data/test/logs mkdir -p data/test/db # 创建配置文件,并写入如下配置 vim bin/mongodb.conf ` # 设置数据文件的存放目录 dbpath = /opt/mongodb/data/test/db # 设置日志文件的存放目录及其日志文件名 logpath = /opt/mongodb/data/test/logs/mongodb.log # 设置端口号(默认的端口号是27017,可以根据个人需求进行更改) port = 27017 # 设置为以守护进程的方式运行,即在后台运行 fork = true # 是否不允许表扫描 nohttpinterface = true ` # 保存退出
启动mongodb# 以配置文件的方式启动 ./bin/mongod --config mongodb.conf
报错一:ERROR: child process failed, exited with error number 1
检查mongodb.conf的文件路径是否配置错误
报错二:ERROR: child process failed, exited with error number 100
很可能是没有正常关闭导致的,那么可以删除mongod.lock文件,这里对应我的配置路径在data/里面
其他# 链接命令,方便调用mongo命令 ln -s /opt/mongodb/bin/mongo /usr/bin # 查看mongodb进程 ps -aux |grep mongodb # 检查端口运行情况 netstat -lanp | grep 27017 # 终止mongodb服务,PID从ps命令获取 kill -15 PID # 添加自启动命令 vim /etc/rc.local # 末尾追加一行 `/opt/mongodb/bin/mongod --config mongodb.conf` # 保存退出
设置密码权限,默认无密码# 进行mongodb的交互环境 ./mongo # 如果进入失败,请检查是否添加了软链接和是否启动了mongodb服务 # 进行admin数据库,创建管理员用户root,密码为password,权限是超级用户(最高) >use admin >db.createUser({user:"root",pwd:"password",roles:["root"]}) # 验证是否创建成功,返回1表示成功 >db.auth({"root", "password"}) # 退出交互环境 >exit # 重启mongodb服务 # 杀死mongodb进程,参照上面的方法 # 以密码权限验证启动服务 opt/mongodb/mongod --config mongodb.conf --auth
数据库权限说明表
名称 | 权限 |
---|---|
数据库用户角色 | read、readWrite |
数据库管理角色 | dbAdmin、dbOwner、userAdmin |
集群管理角色 | clusterAdmin、clusterManager、clusterMonitor、hostManager |
备份恢复角色 | backup、restore |
所有数据库角色 | readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase |
超级用户角色 | root |
提供了系统超级用户的访问 | dbOwner 、userAdmin、userAdminAnyDatabase |
内部角色 | __system |
使用Python连接Mongodb
# 下载第三方包 pip3 install pymongo
# /usr/bin/python3 from pymongo import MongoClient # 方法一 # host主机名,27017连接端口 client = MongoClient(host, 27017) db_auth = client.admin # 登陆的用户名(username)和密码(password) db_auth.authenticate(username, password) # 连接指定数据库,数据库名为db_name db_name = client["db_name"] # 方法二 # 用户名(username)、密码(password)、主机名(host)、端口(port)。注:这里的password不能出现@符号,如果用@符号就需要使用方法一 client = MongoClient("mongodb://username:password@host:port") # 连接指定数据库,数据库名为db_name db_name = client["db_name"] # 操作数据库,db_name["db_set"]=db_name.db_set """ 查找数据 在db_name数据库中的db_set集合里面找到name是a_name的json find是返回一个指针(可以使用列表的方式来读取),find_one返回一个dict """ db_name["db_set"].find_one({"name": "a_name"}) # 插入数据 # 插入一个json到set1集合中,a_dict是一个字典(如果set1不存在则会被自动创建) db_name.set1.insert_one(a_dict) # 插入多个json到set1集合中,a_dict_lst是一个列表,里面的元素是由字典组成的 db_name.set1.insert_many(a_dict_lst) # 更新数据 # 查找到一个数据之后,对里面的某个数据进行更改,再使用save方法保存 data_one = db_name["db_set"].find_one({"name": "a_name"}) data_one['age'] += 3 db_name.db_set.save(data_one) # 更新多条记录,找到db_set集合中满足age=20,sex=0的数据,将name改为user1 db_name.db_set.update({"name": "user1"}, {"$set":{"age": 20, "sex": 0}}) # 删除数据 id = db_name.db_set.find_one({"name": "user1"})["_id"] # 根据 id 删除一条记录 db_name.db_set.remove(id) # 删除集合里的所有记录 db_name.db_set.remove() # 删除name=user1的记录 db_name.db_set.remove({"name": "user1"})
可视化Mongodb的操作
强烈推荐Robo 3t,官网地址到官网找到对应的系统版本进行下载
安装
Windows的安装十分简单就不赘述了
Ubuntu的安装
# 解压缩 tar -zxzf robomongo*.tar.gz # 修改文件名(可选) mv robomongo* robo3t # 移动到/opt目录(可选) mv robo3t /opt # 建立软链接 ln -s /opt/robo3t/robomongo /usr/bin # 启动 robomongo
# 如果报如下错误 ` This application failed to start because it could not find or load the Qt platform plugin "xcb" in "". Available platform plugins are: xcb. Reinstalling the application may fix this problem. Aborted (core dumped) ` # 解决办法 mkdir ~/robo-backup mv /opt/robo3t/lib/libstdc++* ~/robo-backup/ # 之后便可以重新启动mongo试试看了
使用
首先创建新的连接,如下图所示。在
Connection中,``Name为自定义连接名,
Address填入对应的
host和
port;
在
Authentication中,勾选
Perform authentication,填上对应的
User Name和
Password。填写完成之后可以点击
Test验证是否能够连接成功,如果无误的话,可以点击
Save保存退出。
连接Mongodb。点击
Connect,之后就可以可视化数据库中的数据。也可以使用鼠标简单的进行创建/删除数据库,新建/修改信息,也可以使用命令查找数据。
进阶操作
例子:# test_db { "_id" : ObjectId("56063f17ade2f21f36b03133"), "title" : "MongoDB 教程", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "菜鸟教程", "url" : "http://www.runoob.com", "tags" : [ "mongodb", "database", "NoSQL" ], "links" : [{ "UserName" : "@a1bf7a55ad8478017b95124774687769", "Uin" : 12266535, "NickName" : "一二三", }, { "UserName" : "@5571e120b5d8f54f93338c76f62b9c419b818c29373dca9f331c2911a203bfbe", "Uin" : NumberLong(3379331828), "NickName" : "灵灵八", }] }
# 返回查找结果的数目 db.test_db.find({"title": "MongoDB 教程"}).count() # 查找某个key中的数组是否某包含某内容 db.test_db.find({"tags": {"$in": ["mongodb"]}}) # 使用正则进行查找 db.test_db.find({"url": {"$regex": "^http"}}) # 查找某个由数组构成的key方法 db.test_db.find({"links":{"$elemMatch":{"Uin":12266535,"NickName":"一二三"}}})
相关文章推荐
- MongoDB 学习笔记(python操作)
- MongoDB 学习笔记(python操作)
- Ubuntu中安装MongoDB及执行一些简单操作笔记
- MongoDB 学习笔记(python操作)
- Python笔记2:Ubuntu下安装MySQL及MySQL终端操作命令
- MongoDB 学习笔记(一):安装及简单shell操作
- Python学习笔记(3):MongoDB的安装
- MongoDB 学习笔记(python操作)
- MongoDB 学习笔记(一):安装及简单shell操作
- MongoDB 学习笔记(python操作)
- Ubuntu中安装MongoDB及执行一些简单操作笔记
- Ubuntu中安装MongoDB及执行一些简单操作笔记
- python学习笔记操作mongodb(九)
- MongoDB 学习笔记(python操作)
- python学习笔记(mysqldb下载安装及简单操作)
- mongoDB学习笔记3--python下使用
- Dive in Python学习笔记一:安装Python
- Python Django 学习笔记 软件下载及安装(一)
- python+django+mysql学习笔记 (一) – 安装篇
- Python笔记——python简介、特点、安装及helloworld