(1) mongodb的安装

下载tgz解压后,需要添加相应的环境变量才能在终端直接启动mongod。

mongodb数据存储在/data/db中,需要手动创建目录树,同时mongod执行的时候如果权限不够(不能往/data/db写东西),需要改一下权限。

vim ~/.bashrc
export PATH="~/download/mongodb-linux-x86_64-ubuntu/bin:$PATH" mkdir -p /data/db ls -l / 查看data目录的权限,发现拥有者可写
ls -l /data 查看db目录的权限,发现拥有者可写
chown -R "liaohuqiang" /data data下的所有文件的拥有者改为自己 

(2) mongod的启动

之后就可以在终端上输入mongod,这个时候就启动了mongodb,但是这个时候是在终端运行着的,相当于一个前台进程,在这个终端你不能做其它操作。

可以使用--fork选项,开启后会回到终端交互,可以继续做自己的事。

fork表示以守护进程的方式启动mongodb,创建一个服务器进程。fork要配合logpath使用,表示日志信息输出到哪个日志文件。logappend表示以追加的方式写入日志文件。

当然还有别的启动方式,目前还没用到,暂时先不说。

如果想设置成开机自动启动,就把这句加到/etc/rc.local中(把mongod指令换成mongod所在的位置,比如/home/liaohuqiang/download/mongodb3.4.5/bin/mongod)

mongod --fork --logpath ~/mongo.log --logappend

可以查看mongod是否启动

sudo netstat -anp | grep "mongo"

(3)mongo的使用

启动mongod后就可以在终端进入mongo进行相关数据库操作

show dbs 显示所有数据库
use doctor 切换到某个数据库"doctor", 不切换的话默认使用test db.dropDatabase() 删除数据库
show collections 显示所有集合
db.sample.drop() 删除集合 db.sample.insert({name:"pilgrimHui", label:"1"}) 插入一行记录
db.sample.insert({...}) 如果文档已存在,会更新_id,不存在则同insert db.sample.find({...}) 查找满足条件的记录,简单的一些查询条件见下面
db.sample.find({...},{field1:1, field2:1}) 只找出某些字段
db.sample.find() 查找sample集合所有记录 db.sample.remove({...},1) 删除满足条件的记录,参数1可选,代表只删除1个
db.sample.remove({}) 删除sample集合的所有记录

(4) mongo里的update操作

db.collection.update(criteria, objNew, upsert, multi)
criteria: 查询条件,理解为sql update语句where后面的
objNew: 更新操作,理解为sql update语句set后面的
upsert: 如果不存在查询到的记录,是否插入。默认false,不插入
multi: 是否更新多条。默认false,只更新第一条。 # 例如:把集合里所有记录的status改为0
db.sample.update({"status": {$ne: } }, {$set: {"status":}}, {multi: true})
或者
db.sample.update({"status": {$ne: } }, {$set: {"status":}}, false,true)

(4) 几个查询操作符

$ne 不等
$gt 大于
$gte 大于等于
$lt 小于
$lte 小于等于
$in和$nin 是否在指定数组中
$all 是否全在指定数组中
$or 将数组中的多个键值对或运算
$slice:[1,2] 切片,取属性值(数组)的某几个
$size 该属性值(数组)的长度
$exists:true 选择该字段存在的记录
$not 对任何查询操作符取非
$regex 使用正则表达式匹配

(5) 几个更新操作符

{ $inc : { field : value } }
{ $set : { field : value } }
{ $unset : { field : } }
{ $push : { field : value } } 追加,field要是数组
{ $pull : { field : value } } 和push相反
{ $pop : { field : } } 删除最后1个值
{ $pop : { field : - } } 删除第1个值 
{ $currentDate: { <field1>: {$type:"date", ... } } 设定当前时间
{ $rename: {<field1>:<newName1>,<field2>:<newName2>,...} } 重命名字段

(6) 用户权限设置

mongodb默认没有帐号登录,需要自己先添加帐号。

在admin数据库添加的帐号为管理员帐号,在其它数据库添加的帐号为普通用户

用户只能在用户所在的数据库登录,包括管理员。

管理员只能在admin登录认证后才能管理其它数据库。

6.1 添加管理员帐号

use admin
db.system.users.find()
db.addUser('liaohuqiang','liaohuqiang') # 添加管理员用户,mongodb版本不同,可能会报错,如果报错找不到addUser则用下面这个 db.createUser(
{
user: 'liaohuqiang',
pwd: 'liaohuqiang',
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
) # 版本不同的问题:以上createUser在2.4.9中有用。
# 但是我在自己电脑3.4.5中创建后的用户,无法在其它数据库中使用,这个时候用另一个roles就可以了。
db.createUser({user:"admin",pwd:"password",roles:["root"]}) # 不同版本的授权有所不同,这个需要自行留意。

6.2 重新启动mongod

创建成功后重启mongod,这个时候开启连接可以带上--auth选项,代表验证用户权限。

mongod --fork --logpath ~/mongo.log --logappend --auth

6.3 认证登录

开启后,直接mongo进去操作会受限,可以mongo连接时授权登录;也可以连接进去后再认证。

mongo -u liaohuqiang -p --authenticationDatabase admin
mysql -h ip -u root -p 乱入,对比一下mysql的连接 mongo
use admin
db.auth('liaohuqiang', 'liaohuqiang')

6.4 关闭连接

认证登录后就可以像之前那样操作数据库了,操作完后可以在admin数据库关闭连接。

use admin
db.shutdownServer() 关闭mongod

(7) pymongo的连接和使用

import pymongo

client=pymongo.MongoClient('mongodb://username:password@ip')
db=client['doctor']
users=db["user"] result= list(users.find( {'role':1}, {'_id':0} ) ) 选多个
result= users.find_one({"name":name}) 选单个 users.insert_one({"name":name}) 插一个,会自动生成主键 users.remove( {"name":name}, {"multi":True} ) 删多个
users.update_one({'name':name},{'$inc':{'commitCount':1}}) 改一个

最新文章

  1. 使用AFNetWorking 实现以Basic Authentication方式获取access-token
  2. Oracle 逐条和批量插入数据方式对比
  3. web客户端通过ajaxfileupload方式上传文件
  4. oracle两种导出导入方式,即imp与impdp之比较
  5. 网站开发常用jQuery插件总结(九)侧边栏插件pageslide
  6. Axure7.0.0.3155注册码
  7. arTemplate解析语法
  8. Linux中cat、more、less、tail、head命令的区别
  9. SoapUI模拟REST MockService
  10. [Swift]LeetCode895. 最大频率栈 | Maximum Frequency Stack
  11. K8S 部署 ingress-nginx (一) 原理及搭建
  12. Linux中查看你的用户是否为root用户
  13. Strust2框架笔记01_XML配置_action编写
  14. Shiro会话管理器与验证码实现(十四)
  15. js数据类型 --运算符
  16. dedecms织梦首页判断,添加不同标题
  17. LitJson JavaScriptSerializer
  18. 最小生成树-普利姆算法lazy实现
  19. Kafka剖析:Kafka背景及架构介绍
  20. u-boot 2016.05 添加自己的board 以及config.h

热门文章

  1. PHP实现懒加载
  2. CVPR(IEEE Conference on Computer Vision and Pattern Recognition)
  3. 第二百二十一节,jQuery EasyUI,Form(表单)组件
  4. Sql server 打不开了,无法识别的配置节 system.serviceModel 解决方案
  5. java 理解java的三大特性之继承
  6. web html 防盗链
  7. ActiveMQ安装优化
  8. 重写ListView解决ListView内部ViewPaper滑动事件冲突问题
  9. python bottle学习(二)加载配置文件
  10. HTTP错误 401.3