MongoDB

MongoDB介绍

最广泛用于地图类系统

360是中国最大的MongoDB集群应用商

MongoDB的特性:

既有非关系型的灵活模式、扩展性,又有关系型的强大查询功能,强大一致性、二级索引。

设计哲学:

(1)反范式;(2)水平扩展;(3)高可用性;(4)泛目的

一、安装

mysql 3306
redis    6379
mongodb    27017

1.安装

2.添加环境变量

3.在cmd中输入mongod,根据报错信息创建/data/db目录

4.开启mongodb服务端:mongod

5.开启mongodb客户端:mongo

二、初级使用

show dbs 查看当前服务器存在多少DB,只能看到磁盘上的database,我们新建的database不会立马在磁盘上

use ss1db CreateDatabase 使用不存在的对象即创建该对象 没有即创建

show tables 查看当前DB中有多少表(Collection)

(一)mongodb的数据存储结构 

表——collection

数据行——document

user = [{
name:dragon,
age:20,
gender:"man"
},]

(二)mongodb的增删改查

增:

insert x 官方已经不推荐使用这个LowB的方法了

insertOne({name:"123"}) 插入一条数据行(document)

insertMany([{name:"123"},{name:"234"},{name:"345"}]) 插入多行数据

查:

#查的时候没有findMany

findOne({name:"123"}) 查询满足条件的第一条数据

find({name:"123"}) 查询所有满足条件的数据

改:

#update x 官方已经不推荐使用这个LowB的方法了

updateOne({name:"123"},{$set:{gender:"man",age:20}}) 
# 修改满足条件的第一条数据

updateMany({name:"123"},{$set:{gender:"man",age:20}}) 
# 修改所有满足条件的数据
# $set: 修改器,将某个Key的值修改为某个值

删:

deleteOne({name:"123"}) 删除满足条件的第一条数据

deleteMany({name:"123"}) 删除所有满足条件的数据

remove({})清空数据

(三)mongodb中的数据类型:

varchar----------String
float------------double
double-----------double
date-------------ISODate
int--------------int
boolean----------boolean
NUll-------------Null
array------------Arrays
object-----------Object

ObjectID :Documents 自生成的 _id
String: 字符串,必须是utf-8
Boolean:布尔值,true 或者false (这里有坑哦~在我们大Python中 True False 首字母大写)
Integer:整数 (Int32 Int64 你们就知道有个Int就行了,一般我们用Int32)
Double:浮点数 (没有float类型,所有小数都是Double)
Arrays:数组或者列表,多个值存储到一个键 (list哦,大Python中的List哦)
Object:如果你学过Python的话,那么这个概念特别好理解,就是Python中的字典,这个数据类型就是字典
Null:空数据类型 , 一个特殊的概念,None Null
Timestamp:时间戳
ISODate:存储当前日期或时间unix时间格式 (我们一般不用这个Date类型,时间戳可以秒杀一切时间类型)

$关键字:数学比较符

db.student.find({age:{$lt:25}})  # 小于

db.student.find({age:{$lte:25}})  # 小于等于

db.student.find({age:{$gt:23}})  # 大于

db.student.find({age:{$gte:23}})  #大于等于

$修改器:

1.$set: 将某个Key的值修改为某个值

2.$unset: 删除字段(field) 
db.student.updateOne({age:84},{$unset:{head:1}})

3.$inc : 将原有值增加多少 
db.student.updateOne({age:85},{$inc:{age:1000}})

4.$push: [].append() 在arrays中在最后位置追加一个数据 db.student.updateOne({age:1085},{$push:{hobby:"chezhen"}})

5.$pull: [].remove(item) 在array中删除一个元素 db.student.updateOne({age:1085},{$pull:{hobby:"chezhen"}})

6.$pop : 删除array中的第一个或最后一个元素,-1:第一个 1:最后一个

$字符的特殊用法:

符合array检索条件的元素下标
db.student.updateMany({hobby:69},{$set:{"hobby.$":78}})

遇到array中包含object时使用以下方式:

db.school.updateOne({"price.price":17800},{$set:{"price.$.name":"linux"}})

db.school.updateOne({"price.name":"linux"},{$set:{"price.1.name":"linux云计算"}})


limit(2) : 选取,从0-2的数据
skip(2) : 跳过 2 条数据 从第3条数据开始
sort({age:1}) : 根据age字段进行从小到大的排序(升序) -1:降序

分页查询:

limit(count).skip(page+count)

二、pymongo

(一)连接字符串:

mongo_conn = pymongo.MongoClient(host="127.0.0.1",port=27017)   # 建立连接
mongo_db = mongo_conn["ss1db"]  # 选取数据

(二)查询:

res = mongo_db.student.find({"name":"alex"}) 
# pymongo的Cursor对象需要循环
for i in res:
print(i)

res = mongo_db.student.find_one({"age":25}) 
# 返回的是一个Dict
print(res)

(三)增加:

res = mongo_db.student.insert_one({"name":"nezha","age":20})
print(res) #inserOneResult
print(res.inserted_id) # 当前插入对象的_id

res = mongo_db.student.insert_many([{"name":"nezha1","age":20},{"name":"nezha2","age":20}])
print(res)  #inserManyResult
print(res.inserted_ids)  # 当前插入所有对象的_id 是个list

(四)更新:

res = mongo_db.student.update_one({"name":"nezha1"},{"$set":{"age":22}})
print(res)  # UpdateResult
print(res.acknowledged)  # True 更新成功

res = mongo_db.student.update_many({"age":30},{"$set":{"age":25}})
print(res) # UpdateResult
print(res.raw_result) # 受影响行数
print(res.acknowledged) # True 更新成功

(五)删除:

res = mongo_db.student.delete_one({"name":"nezha1"})
print(res) #DeleteResult
print(res.acknowledged) # True 删除成功
print(res.deleted_count) # 删除行数 只能是1
print(res.raw_result) 受影响行数

res = mongo_db.student.delete_many({"age":25})
print(res) #DeleteResult
print(res.acknowledged) # True 删除成功
print(res.deleted_count) # 删除行数 可以大于1
print(res.raw_result) #受影响行数

(六)清除数据:

res = mongo_db.student.remove({})
print(res) # 受影响行数 返回值 n > 0 清楚成功


# 查询_id等于 5b7e0a6eaeb4a3336c0f9b71
# from bson import ObjectId #必须使用ObjectId去查询_id
# res = mongo_db.school.find_one({"_id":ObjectId("5b7e0a6eaeb4a3336c0f9b71")})
# print(res)

limit skip sort:
sort的用法,与pymysql中的用法及其相似,已经不是mongodb中的sort用法
res = mongo_db.school.find({}).limit(2).skip(1).sort("name",pymongo.ASCENDING)
for i in res:
print(i)
原文地址:https://www.cnblogs.com/qiaoqianshitou/p/9576791.html