mongodb存储的基本使用
Python连接mongodb一般使用pymongo模块
1. pymongo模块的简单使用
### MongoDB存储 ## 连接MongoDB
import pymongo # 建立连接对象,2种方法皆可
client = pymongo.MongoClient(host='10.0.0.100', port=27017)
client2 = pymongo.MongoClient('mongodb://10.0.0.100:27017/') # 指定数据库,如无则创建
db = client.test
db2 = client2['test'] # 指定集合,如无则创建
collection = db.students
collection2 = db2['students'] # 插入数据,字典格式
stu = {
'name': 'dmr',
'age': '25',
'score': '80',
'gender': 'frail'
}
stu2 = {
'name': 'asx',
'age': '23',
'score': '81',
'gender': 'frail'
}
stu3 = {
'name': 'scy',
'age': '26',
'score': '66',
'gender': 'male'
}
# result = collection.insert_one(stu)
# result2 = collection.insert_many([stu2, stu3])
# print(result2, result.inserted_id) '''
输出内容:
<pymongo.results.InsertManyResult object at 0x0000000002E9D688> 5e70908ba7233089f696168e
''' # 查询,
# find_one()查询到单个结果返回一个字典,如匹配到多个值则返回匹配到的第一个值
# find()则返回一个生成器对象
## 比较符号
# $lt 小于 {'age': {'$lt': 20}}
# $gt 大于 {'age': {'$gt': 20}}
# $lte 小于等于 {'age': {'$lte': 20}}
# $gte 大于等于 {'age': {'$gte': 20}}
# $ne 不等于 {'age': {'$ne': 20}}
# $in 范围内 {'age': {'$in': [20, 24]}}
# $nin 范围外 {'age': {'$nin': [20, 24]}}
## 功能符号
# $regex 匹配正则表达式 {'name': {'$regex': '^d.*'}} 名字以d开头的
# $exists 属性是否存在 {'name': {'$exists': True}} name属性存在则返回存在的内容
# $type 类型判断 {'age': {'$type': 'int'}} age的类型是否为int,匹配则返回匹配的内容
# $text 匹配正则表达式 {'$text': {'$search': 'dm'}} text类型的属性中包含dm字符串
result = collection.find_one({'name': 'dmr'})
result2 = collection.find({'name': 'dmr'})
print(type(result), type(result2))
print(result, result2)
result = collection.find_one({'gender': 'frail'})
result2 = collection.find({'gender': 'frail'})
print(type(result), type(result2))
print(result, result2)
for item in result2:
print(item) '''
输出内容:
<class 'dict'> <class 'pymongo.cursor.Cursor'>
{'_id': ObjectId('5e708dd5b7d59968e4f1ffef'), 'name': 'dmr', 'age': '25', 'score': '80'} <pymongo.cursor.Cursor object at 0x0000000002E9B7B8>
<class 'dict'> <class 'pymongo.cursor.Cursor'>
{'_id': ObjectId('5e709140e0fe6500676f15c3'), 'name': 'dmr', 'age': '25', 'score': '80', 'gender': 'frail'} <pymongo.cursor.Cursor object at 0x0000000002E9BA90>
{'_id': ObjectId('5e709140e0fe6500676f15c3'), 'name': 'dmr', 'age': '25', 'score': '80', 'gender': 'frail'}
{'_id': ObjectId('5e709140e0fe6500676f15c4'), 'name': 'asx', 'age': '23', 'score': '81', 'gender': 'frail'}
''' ## 计数
count = collection.find({'gender': {'$exists': True}}).count()
print(count) ## 排序
results = collection.find().sort('_id', pymongo.ASCENDING)
print(results)
print([i for i in results]) ## 偏移,skip(2)及忽略前2个元素,limit(2)选择前2个元素,后面的元素忽略
results = collection.find().sort('_id', pymongo.ASCENDING).skip(2)
print(results)
print([i for i in results]) ## 更新
old = {
'name': 'dmr'
}
new = {
'age': 20
}
# 直接替换整条内容
result = collection.update(old, new)
result2 = collection.update_one(old, {'$set': new})
# 仅修改new中键值的内容
result3 = collection.update(old, {'$set': new})
result4 = collection.update_many(old, {'$set': new})
print(result, result2)
r2 = collection.find()
for i in r2:
print(i) ## 删除,remove,delete_one,delete_many
result = collection.remove({'name': 'dmr'})
print(result)
result2 = collection.delete_one({'name': 'dmr'})
print(result2.deleted_count)
result3 = collection.delete_many({'name': 'scy'})
print(result3.deleted_count)
result4 = collection.find()
for i in result4:
print(i)
mongodb存储的基本使用的更多相关文章
- MongoDB 存储引擎和数据模型设计
标签: MongoDB NoSQL MongoDB 存储引擎和数据模型设计 1. 存储引擎 1.1 存储引擎是什么 1.2 MongoDB中的默认存储引擎 2. 数据模型设计 2.1 内嵌和引用 2. ...
- 了解mongoDB存储结构
mongoDB 深入浅出一 了解mongoDB存储结构 MongoDB 深入浅出 数据逻辑结构 1 mongoDB中的文档(document) 相当于 关系性数据库的一条一条的记录 2 colle ...
- Asp.Net Core Web Api图片上传(一)集成MongoDB存储实例教程
Asp.Net Core Web Api图片上传及MongoDB存储实例教程(一) 图片或者文件上传相信大家在开发中应该都会用到吧,有的时候还要对图片生成缩略图.那么如何在Asp.Net Core W ...
- 使用 MongoDB 存储日志数据
使用 MongoDB 存储日志数据 线上运行的服务会产生大量的运行及访问日志,日志里会包含一些错误.警告.及用户行为等信息.通常服务会以文本的形式记录日志信息,这样可读性强,方便于日常定位问题 ...
- MongoDB存储引擎选择
MongoDB存储引擎选择 MongoDB存储引擎构架 插件式存储引擎, MongoDB 3.0引入了插件式存储引擎API,为第三方的存储引擎厂商加入MongoDB提供了方便,这一变化无疑参考了MyS ...
- MongoDB 存储日志数据
MongoDB 存储日志数据 https://www.cnblogs.com/nongchaoer/archive/2017/01/11/6274242.html 线上运行的服务会产生大量的运行及访问 ...
- 使用 MongoDB 存储商品分类信息
此文已由作者温正湖授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 这是一篇MongoDB官网上的一篇文章,分析了使用MongoDB存储商品分类信息相比其他数据库的优势,并讲述 ...
- 数据存储之非关系型数据库存储----MongoDB存储
MongoDB存储----文档型数据库 利用pymongo连接MongoDB import pymongo client = pymongo.MongoClient(host='localhost', ...
- MongoDB学习笔记(五、MongoDB存储引擎与索引)
目录: mongoDB存储引擎 mongoDB索引 索引的属性 MongoDB查询优化 mongoDB存储引擎: 目前mongoDB的存储引擎分为三种: 1.WiredTiger存储引擎: a.Con ...
- MongoDB 存储引擎选择
MongoDB存储引擎选择 MongoDB存储引擎构架 插件式存储引擎, MongoDB 3.0引入了插件式存储引擎API,为第三方的存储引擎厂商加入MongoDB提供了方便,这一变化无疑参考了MyS ...
随机推荐
- UltraSoft - Alpha - Scrum Meeting 5
Date: Apr q9th, 2020. Scrum 情况汇报 进度情况 组员 负责 昨日进度 后两日任务 CookieLau PM 统筹个人进度,协助推进进度 辅助前后端连接工作 刘zh 前端 完 ...
- 技术博客——微信小程序的架构与原理
技术博客--微信小程序的架构与原理 在两个月的微信小程序开发过程中,我曾走了不少弯路,也曾被很多现在看来十分可笑的问题所困扰.这些弯路与困扰,基本上都是由于当时对小程序的架构理解不够充分,对小程序的原 ...
- js--数组的 fill() 填充方法详解
前言 我们知道了很多了初始化数组的方法,但是初始化数组之后,数组中的每一项元素默认为 empty 空位占位,如何对数组这些空位添加默认的元素,ES6提供了 fill() 方法实现这一操作.本文总结数组 ...
- 为什么用于开关电源的开关管一般用MOS管而不是三极管
区别: 1.MOS管损耗比三极管小,导通后压降理论上为0. 2.MOS管为电压驱动型,只需要给电压即可,意思是即便串入一个100K的电阻,只要电压够,MOS管还是能够导通. 3.MOS管的温度特性要比 ...
- 零基础学习Linux所必备的七大习惯
对于很多Linux初学者来说,在刚开始使用linux系统时会感到很多的不适.这里为大家整理了自己以前linux入门时别人告诉我的七个习惯.我相信如果你运用了这七个习惯,在你使用Linux时你会感觉更安 ...
- Tomcat 内存马(一)Listener型
一.Tomcat介绍 Tomcat的主要功能 tomcat作为一个 Web 服务器,实现了两个非常核心的功能: Http 服务器功能:进行 Socket 通信(基于 TCP/IP),解析 HTTP 报 ...
- Socket `accept queue is full ` 但是一个连接需要从SYN->ACCEPT
由于标题长度有限制,我把想要描述的问题再次描述下: 内核通常会为每一个LISTEN状态的Socket维护两个队列: 1 accept队列: listen()函数第二个参数BACKLOG指定,表示已完成 ...
- Java的基本数据类型和数据类型转换
首先java属于强类型语言,要求变量的使用要严格遵守规范,所有变量都必须先定义后才能使用. Java的数据类型分为以下两种: 1 基础数据类型(primtive type) 和 2 引用数据类型(re ...
- 手把手从0到1:搭建Kubernetes集群
搭建 k8s 集群网上很多教程,如果是手工部署或者实验环境可以直接使用 MiniKube 或者 Kind,来在本地启动简单的 Kubernetes 集群进行后面的学习即可.如果是使用 MiniKube ...
- 部署一个支持Dapr 的Kubernetes APISIX Ingress
在这篇文章中,我将展示如何创建一个 APISIX控制器,该控制器在 Kubernetes 集群中公开启用 Dapr 的应用程序. 本质上,APISIX控制器将配置相同的标准 Dapr annotati ...