MongoDB,pymongo
MongoDB:
数据库,nosql
[{
id:1
name:"蔡文姬"
age: 16
gender:"女"
},
{
id:1
name:"蔡文姬"
age: 16
sex:["女","girl","老阿姨"]
other:{
hobby:["男","boy","小哥哥"]
}
}] *使用了不存在的对象即创建该对象
*不存在关系链接 插入:
db.users.insert({name:"蔡文姬",age:16}) # 建议不要使用 不推荐使用
查询:
db.users.find()
更新:
db.users.update({"name":"蔡文姬"},{$set:{"age":18}})# 建议不要使用 不推荐使用
删除:
db.users.remove({"age":21}) # 建议不要使用 不推荐使用 table Collections 表
row Documents 数据条目
column Field 字段 MongoDB数据类型:
Object ID :Documents 自生成的 _id 并且 不支持转换成JSON字符串
?:{"_id" : ObjectId("5bda5293c6c72e52ffc7e91e")}
ObjectId:"5bda5293c6c72e52ffc7e91e"
0-8字节是时间戳,
9-14字节的机器标识符,表示MongoDB实例所在机器的不同;
15-18字节的进程id,表示相同机器的不同MongoDB进程。
19-24字节是计数器 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:时间戳
Date:存储当前日期或时间unix时间格式 (我们一般不用这个Date类型,时间戳可以秒杀一切时间类型) 增删改查的支持方式:
insert:
db.users.insertMany([{"name":"金王吧"},{"name":"egon"}])
db.users.insertOne({"name":"刘sir"}) remove:
db.users.deleteOne({"age":30})
db.users.deleteMany({"age":30}) update:
db.users.updateOne({},{$set: {"cursors":"FullStack"}})
db.users.updateMany({},{$set: {"cursors":"FullStack"}}) find:
db.users.find({})
db.users.findOne({}) 数学比较符:
$lt: <
$lte: <=
$gt: >
$gte: >=
$eq;==
: : == or = $:
存储满足条件的数据下标索引位置
db.users.updateOne({"other.name":"linux","name":"银网吧"},{$set:{"other.$.score":19}}) 弊端:[
[1,2,3],
[{k:{zk:zv}},{k2:v2},{k3:v3}],
[4,5,6],
] $关键字 查询:
$or : db.users.find({$or:[{age:18},{name:"银网吧"}]}) $and : , $in : db.users.find({age:{$in:[18,84,73]}}) $all : db.users.find({hobby:{$all:[1,2,3,4,5,6]}}) $修改器 update:
$set: 直接将字段的值设定为value
$unset: 删除字段
$inc: 原值增加 db.users.updateMany({name:"金王吧"},{$inc: {cursors: 1}}) $array修改器:
$push : append(item) db.users.updateMany({name:"金王吧"},{$push: {hobby:10}})
$pull : remove(item) db.users.updateMany({name:"金王吧"},{$pull: {hobby:10}})
$pop : pop() db.users.updateMany({name:"金王吧"},{$pop: {hobby:-1}}) 1最后一个 -1第一个 skip limit sort limit : db.users.find({}).limit(2) 显示条目数量
skip : db.users.find({}).skip(1) 跳过条目数量 简单分页 :db.users.find({}).limit(每页条目).skip(当前页码*每页条目)
sort :db.users.find({}).sort({ age:1 }) 1:ASC -1:DESC
分页排序多重用法:
db.users.find({}).sort({ age:-1 }).limit(2).skip(2)
pymongo
import pymongo
mongo = pymongo.MongoClient("127.0.0.1",27017)
MONGODB = mongo["SS2DAY04"]
查:
result = list(MONGODB.users.find({}))
for item in result:
print(item)
print(result)
result_one = MONGODB.users.find_one({})
print(result_one,type(result_one))
print(result_one.get("_id"),type(result_one.get("_id")))
增:
res = MONGODB.student.insert_one({"name":"yd","nickname":"wl"})
print(res.inserted_id,type(res.inserted_id))
res = MONGODB.student.insert_many([{"name":"yd","nickname":"wl"},{"name":"wpq","nickname":"cb"},{"name":"lj","nickname":"dsb"}])
print(res.inserted_ids)
删:
MONGODB.student.remove({})
MONGODB.student.delete_one({"name":"yd"})
MONGODB.student.delete_many({"name":"yd"})
改:
MONGODB.student.update({"name":"yd"})
MONGODB.student.update_one({"name":"wpq"},{"$set":{"nickname":"peppa pig"}})
MONGODB.student.update_many({},{"$set":{"age":84}})
删:
MONGODB.student.delete_many({}) # 值删除所有数据
MONGODB.student.drop() # 删除表
分页:
res = MONGODB.users.find({}).sort("age",pymongo.ASCENDING).limit(2).skip(0)
for i in res:
print(i)
MongoDB,pymongo的更多相关文章
- [mongoDB]PyMongo Cursor Not Found Error
Python跑一个aggregate脚本,报错:pymongo.errors.CursorNotFound: Cursor not found, cursor id: 35411720832 搜了下原 ...
- MongoDB pymongo模块
安装pymongo模块 pip install pymongo 连接mongodb代码,生成pymongo对象,传入连接服务器相关参数 ip 端口 如果使用指定的账户登录,设置要登录的账户和密码,然后 ...
- Python操作MongoDB(PyMongo模块的使用)
#!/usr/bin/env python #coding:utf-8 # Author: --<qingfengkuyu> # Purpose: MongoDB的使用 # Creat ...
- python操作mongoDB(pymongo的使用)
pymongo操作手册 连接数据库 方法一(推荐) import pymongo client = pymongo.MongoClient(host="localhost",por ...
- MongoDB pymongo模块 删除数据
使用user集合,删除user集合的数据 import pymongo mongo_client = pymongo.MongoClient( host='192.168.0.112', port=2 ...
- MongoDB pymongo模块 查询
查询 mongo_db 类似于 服务器命令行的db 我们可以db.user.find() 查询 find() 需要加上列表 import pymongo mongo_client = pymongo. ...
- MongoDB pymongo模块 插入数据
insert_one(): 对一张不存在表插入数据,他会在插入数据同时自动生成数据表, 例如我要对chat集合插入数据,插入一个空数据 import pymongo mongo_client = py ...
- MongoDB pymongo模块 更新数据
现在chat集合里有3条数据 import pymongo mongo_client = pymongo.MongoClient( host='192.168.0.112', port=27017, ...
- mongodb pymongo.errors.CursorNotFound: Cursor not found, cursor id: 82792803897
默认 mongo server维护连接的时间窗口是十分钟 默认 单次从 server获取数据是101条或者 大于1M小于16M的数据 所以默认情况下,如果10分钟内未能处理完数据,则抛出该异常. 解决 ...
随机推荐
- 在Unity中实现屏幕空间反射Screen Space Reflection(2)
traceRay函数 在上一篇中,我们有如下签名的traceRay函数 bool traceRay(float3 start, float3 direction, out float2 hitPixe ...
- webpack4 未设置mode会自动压缩
最近想用LayaBox做个小游戏,然而Laya本身不自带构建工具.然后觉得写模块化的东西还是用webpack好使,用es6的语法也比较清晰. 于是就装了webpack,只用babel-loader来编 ...
- git创建新分支推送到远程
1.创建本地分支 git branch 分支名,例如:git branch 2.0.1.20120806 注:2.0.1.20120806是分支名称,可以随便定义. 2.切换本地分支 git ch ...
- virtualenv搭建虚拟环境
最近因为项目需要,要在CentOS 7 上搭建一套开发环境,虽说Python的背后有着庞大的开源社区支持,但是有一个缺点就是每个包的质量都参差不齐,如果我们在工作服务器上去测试安装每个包,就会造成整个 ...
- apache2启动失败(Failed to start The Apache HTTP Server.)解决方案
不知道如何启动apache2就启动不来了. 如下图所示: 即使卸载了重新装也是如此 经过测试卸载并清除软件包的配置即可解决 sudo apt-get purge apache2 sudo apt-g ...
- 74.VS2013和opencv3.1.0安装教程
一.先下载文件 1.VS2013 VS2013有很多版本,专业版,旗舰版,中文英文之类的,所对应的密钥也不一样.我选择的是简体中文专业版.下载链接如下. http://www.musnow.com/t ...
- python之jsonpath的使用
import json import jsonpath import requests url="https://www.lagou.com/lbs/getAllCitySearchLabe ...
- 实现在点击asp:button按钮后,不刷新当前页面
方法1:return false <asp:Button ID="Button1" runat="server" Text="Button&qu ...
- Codeforces Round #441 (Div. 2)
Codeforces Round #441 (Div. 2) A. Trip For Meal 题目描述:给出\(3\)个点,以及任意两个点之间的距离,求从\(1\)个点出发,再走\(n-1\)个点的 ...
- spring中的任务调度Quartz
Spring 整合 Quartz 任务调度 主要有两种方式. Quartz的官网:http://www.quartz-scheduler.org/ 这两种只是一些配置文件简单配置就OK了,但是根本无法 ...