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的更多相关文章

  1. [mongoDB]PyMongo Cursor Not Found Error

    Python跑一个aggregate脚本,报错:pymongo.errors.CursorNotFound: Cursor not found, cursor id: 35411720832 搜了下原 ...

  2. MongoDB pymongo模块

    安装pymongo模块 pip install pymongo 连接mongodb代码,生成pymongo对象,传入连接服务器相关参数 ip 端口 如果使用指定的账户登录,设置要登录的账户和密码,然后 ...

  3. Python操作MongoDB(PyMongo模块的使用)

    #!/usr/bin/env python #coding:utf-8 # Author:   --<qingfengkuyu> # Purpose: MongoDB的使用 # Creat ...

  4. python操作mongoDB(pymongo的使用)

    pymongo操作手册 连接数据库 方法一(推荐) import pymongo client = pymongo.MongoClient(host="localhost",por ...

  5. MongoDB pymongo模块 删除数据

    使用user集合,删除user集合的数据 import pymongo mongo_client = pymongo.MongoClient( host='192.168.0.112', port=2 ...

  6. MongoDB pymongo模块 查询

    查询 mongo_db 类似于 服务器命令行的db 我们可以db.user.find() 查询 find() 需要加上列表 import pymongo mongo_client = pymongo. ...

  7. MongoDB pymongo模块 插入数据

    insert_one(): 对一张不存在表插入数据,他会在插入数据同时自动生成数据表, 例如我要对chat集合插入数据,插入一个空数据 import pymongo mongo_client = py ...

  8. MongoDB pymongo模块 更新数据

    现在chat集合里有3条数据 import pymongo mongo_client = pymongo.MongoClient( host='192.168.0.112', port=27017, ...

  9. mongodb pymongo.errors.CursorNotFound: Cursor not found, cursor id: 82792803897

    默认 mongo server维护连接的时间窗口是十分钟 默认 单次从 server获取数据是101条或者 大于1M小于16M的数据 所以默认情况下,如果10分钟内未能处理完数据,则抛出该异常. 解决 ...

随机推荐

  1. 在Unity中实现屏幕空间反射Screen Space Reflection(2)

    traceRay函数 在上一篇中,我们有如下签名的traceRay函数 bool traceRay(float3 start, float3 direction, out float2 hitPixe ...

  2. webpack4 未设置mode会自动压缩

    最近想用LayaBox做个小游戏,然而Laya本身不自带构建工具.然后觉得写模块化的东西还是用webpack好使,用es6的语法也比较清晰. 于是就装了webpack,只用babel-loader来编 ...

  3. git创建新分支推送到远程

    1.创建本地分支 git branch 分支名,例如:git branch 2.0.1.20120806 注:2.0.1.20120806是分支名称,可以随便定义.   2.切换本地分支 git ch ...

  4. virtualenv搭建虚拟环境

    最近因为项目需要,要在CentOS 7 上搭建一套开发环境,虽说Python的背后有着庞大的开源社区支持,但是有一个缺点就是每个包的质量都参差不齐,如果我们在工作服务器上去测试安装每个包,就会造成整个 ...

  5. apache2启动失败(Failed to start The Apache HTTP Server.)解决方案

    不知道如何启动apache2就启动不来了. 如下图所示: 即使卸载了重新装也是如此 经过测试卸载并清除软件包的配置即可解决 sudo apt-get purge apache2  sudo apt-g ...

  6. 74.VS2013和opencv3.1.0安装教程

    一.先下载文件 1.VS2013 VS2013有很多版本,专业版,旗舰版,中文英文之类的,所对应的密钥也不一样.我选择的是简体中文专业版.下载链接如下. http://www.musnow.com/t ...

  7. python之jsonpath的使用

    import json import jsonpath import requests url="https://www.lagou.com/lbs/getAllCitySearchLabe ...

  8. 实现在点击asp:button按钮后,不刷新当前页面

    方法1:return false <asp:Button ID="Button1" runat="server" Text="Button&qu ...

  9. Codeforces Round #441 (Div. 2)

    Codeforces Round #441 (Div. 2) A. Trip For Meal 题目描述:给出\(3\)个点,以及任意两个点之间的距离,求从\(1\)个点出发,再走\(n-1\)个点的 ...

  10. spring中的任务调度Quartz

    Spring 整合 Quartz 任务调度 主要有两种方式. Quartz的官网:http://www.quartz-scheduler.org/ 这两种只是一些配置文件简单配置就OK了,但是根本无法 ...