广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python怎么操作MongoDB数据库
  • 693
分享到

Python怎么操作MongoDB数据库

2023-07-05 13:07:32 693人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

这篇文章主要介绍“python怎么操作MongoDB数据库”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python怎么操作mongoDB数据库”文章能帮助大家解决问题。一、连接器的安装和配置pym

这篇文章主要介绍“python怎么操作MongoDB数据库”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python怎么操作mongoDB数据库”文章能帮助大家解决问题。

一、连接器的安装和配置

pymongo: MonGoDB 官方提供的 Python 工具包。官方文档: https://pymongo.readthedocs.io/en/stable/ pip安装,命令如下:

pip install pymongo

管理 MongoDB 的主要步骤如下:

  • 连接到 MongoDB 数据库系统

  • 管理 MongoDB 数据库

  • 管理 MongoDB 中的集合

  • 管理 MongoDB 中的文档

第一步,连接 MongoDB:

# 方式一: 使用默认的配置client = MongoClient()# 方式二: 指定主机地址和端口号client = MongoClient('localhost', 27017)# 方式三: 使用URI连接参数client = MongoClient('mongodb://localhost:27017/')

第二步,管理数据库:

#通过MongoClient对象来管理多个数据库获取数据库(逻辑库)对象db = client.DATABASE_NAMEdb = client["DATABASE_NAME"]db = client.get_database(name=None, *args)# 查看所有的数据库(逻辑库)client.list_databases()# 删除数据库(逻辑库)client.drop_database(name_or_database, *args)

第三步,管理集合

# 通过数据库对象db来管理集合# 获取集合对象db = client.DATABASE_NAMEdb.COLLECTION_NAMEclient.DATABASE_NAME.COLLECTION_NAMEdb.get_collection(name, *args)# 查看当前数据库下的集合列表db.list_collection_names()# 删除集合db.drop_collection(name_or_collection, *args)

基础操作示例:

# -*- coding: utf-8 -*-# @Time    : 2023-03-17 1:47# @Author  : AmoXiang# @File    : 1.数据库连接.py# @Software: PyCharm# @Blog    : Https://blog.csdn.net/xw1680from pymongo import MongoClient# 使用默认配置连接到数据库# client = MongoClient()# print(client)# client.close()# 指定主机地址和端口号连接到数据库# client = MongoClient('localhost', 27017)# 使用URI连接参数连接到数据库client = MongoClient('mongodb://localhost:27017/')print(client)# client.close()## # 访问数据库# db = client.test# db = client["test"]# print(db)# db = client.get_database('test')# client.close()# print(db)## 查看有哪些数据库db_list = client.list_databases()# # db_list = client.list_database_names()for item in db_list:    print(item)## 查看数据库下有哪些集合db_test = client["test"]for item in db_test.list_collection_names():    print(item)## # 集合对象操作# data = db_test.students.find_one()# data = client.test.students.find_one()data = client.test.get_collection('students').find_one()print(data)

二、新增文档

说明:pymongo 在插入数据时可以将 python 的对象转换成 BSON

insert_one():插入一个文档

# 调用方法result = db.COLLECTION_NAME.insert_one(doc)# 返回插入的文档IDresult.inserted _id

insert_many():批量新增文档。调用方法:

doc_list = [doc1,doc2]result = db.COLLECTION_NAME.insert_many(doc_list)

示例:

三、查询文档

pymongo 可以将查询的结果转换成 python 中的对象

常用方法:

find_one(): 按条件查询一个文档find(): 按条件查询多个文档count_documents(): 统计满足条件的文档总数aggregate(): 聚合统计.sort(): 排序.skip().limit(): 分页

示例代码:

# -*- coding: utf-8 -*-# @Time    : 2023-03-18 15:03# @Author  : AmoXiang# @File    : 5.查询文档.py# @Software: PyCharm# @Blog    : https://blog.csdn.net/xw1680from bson.objectid import ObjectIdfrom pymongo import MongoClient, ASCENDING, DESCENDINGClass LearnMongoDBSearch(object):    """ MongoDB查询练习 """    def __init__(self):        self.client = MongoClient()    def search_one(self):        """ 查询一个文档 """        temp_obj = self.client.test.newdb.find_one()        print(temp_obj)        print('喜欢分数:', temp_obj['likes'])        # print('注册时间:', temp_obj['reg_date'].date())        print('姓名:', temp_obj['uname'])    def search_user_by_pk(self, pk):        obj_id = ObjectId(pk)        # user_obj = self.client.test.newdb.find_one({'_id': obj_id})        # 面向对象的方法,有代码提示        db = self.client.get_database('test')        users = db.get_collection('newdb')        user_obj = users.find_one({'_id': obj_id})        print(user_obj)    def search_many(self):        """ 查询多个文档 """        db = self.client.get_database('test')        students = db.get_collection('students')        # stu_list = students.find()        # for item in stu_list:        #     print(item)        # 查询年龄大于12岁的学生        stu_list = students.find({'age': {'$gt': 12}}, {'stu_name': 1, 'class_name': 1, 'age': 1})        for item in stu_list:            # 注意:  mongo中存储的整数转换成了浮点数            print(item)    def paginate(self, page=1, page_size=10):        """        分页处理        :param page: 当前的页        :param page_size: 每一页数据大小        :return:        """        db = self.client.get_database('test')        students = db.get_collection('students')        offset = (page - 1) * page_size        stu_list = students.find().skip(offset).limit(page_size)        return stu_list    def sort_data(self):        """ 排序 """        db = self.client.get_database('test')        grades = db.get_collection('grades')        # // 将学生的语文成绩从高到低排序        # db.grades.find({"grade.course_name": "语文"}).sort({"grade.score": -1});        #        # //将学生的语文成绩按照年龄和成绩排序        # db.grades.find({"grade.course_name": "语文"}).sort({"age": -1, "grade.score": -1});        # db.grades.find({"grade.course_name": "语文"}).sort({"grade.score": -1, "age": -1});        # 按某一列排序        # data_list = grades.find({"grade.course_name": "语文"}).sort("grade.score", DESCENDING);        # for item in data_list:        #     print(item)        # 按多列排序        data_list = grades.find({"grade.course_name": "语文"}).sort([('age', DESCENDING),("grade.score", DESCENDING),])        for item in data_list:            print(item)    def counter_students(self):        """ 统计newdb中文档总数 """        db = self.client.get_database('test')        newdb = db.get_collection('newdb')        # result = newdb.count_documents({})        result = newdb.count_documents({"uname": {"$eq": "张三"}})        print(result)    def test_aggregate(self):        """        聚合统计:及格的学生成绩        """        db = self.client.get_database('test')        grades = db.get_collection('grades')        result = grades.aggregate([            # //where            {                '$match': {"grade.score": {'$gte': 60}}            },            # //group by            {                '$group': {                    '_id': "$stu_no",                    'total': {'$sum': 1}                }            },            # // having            {                '$match': {                    'total': {'$eq': 3}                }            }            ])        for item in result:            print(item)if __name__ == '__main__':    obj = LearnMongoDBSearch()    # obj.search_one()    # obj.search_user_by_pk('6411ee77b6170000b4003f95')    # obj.search_many()    # stu_list = obj.paginate(page=3)    # for item in stu_list:    #     print(item)    # obj.sort_data()    # obj.counter_students()    obj.test_aggregate()

四、更新文档

回顾,更新数据表达式,如下表所示:

Python怎么操作MongoDB数据库

修改一个文档,调用方法:

update_one(filter, update, *args)

替换一个文档,调用方法:

replace_one(filter, replacement, *args)

批量修改文档,调用方法:

replace_one(filter, replacement, *args)

快捷方法:

find_one_and_update(filter, update, *args)  # 修改一个文档find_one_and_replace(filter, replacement, *args)  # 替换一个文档# 注意返回值的不同

返回结果:

acknowledged:结果是否已经被确认
modified_count:修改的文档数
matched_count:满足条件的文档数
raw_result:原始数据
upserted_id:更新的ID (upsert=True)

示例代码:

# -*- coding: utf-8 -*-# @Time    : 2023-03-18 14:56# @Author  : AmoXiang# @File    : 4.修改文档.py# @Software: PyCharm# @Blog    : https://blog.csdn.net/xw1680from pymongo import MongoClientclass LearnMongoDBUpdate(object):    """ MongoDB更新练习 """    def __init__(self):        self.client = MongoClient()    def test_update_one(self):        """ 更新一个文档 """        db = self.client.get_database('test')        newdb = db.get_collection('newdb')        result = newdb.update_one({}, {'$set': {'likes': 70}})        print(result.modified_count)    def test_replace_one(self):        """ 替换一个文档 """        db = self.client.get_database('test')        newdb = db.get_collection('newdb')        result = newdb.replace_one({}, {'uname': '张三'})        print(result.modified_count)    def test_update_many(self):        """ 批量更新文档 """        db = self.client.get_database('test')        newdb = db.get_collection('newdb')        result = newdb.update_many({}, {'$set': {'likes': 90}})        print('修改的数量:', result.modified_count)        print('满足条件的数量:', result.matched_count)    def test_update_shortcut(self):        """ 更新文档的快捷方法 """        db = self.client.get_database('test')        newdb = db.get_collection('newdb')        # 此处返回一个文档对象        result = newdb.find_one_and_update({}, {'$set': {'sex': '未知'}})        print(result['_id'])if __name__ == '__main__':    obj = LearnMongoDBUpdate()    # obj.test_update_one()    # obj.test_replace_one()    # obj.test_update_many()    obj.test_update_shortcut()

五、删除文档

删除一个文档,调用方法如下:

result = db.COLLECTION_NAME.delete_one(filter, *args)# 返回已经删除的记录数 result.deleted_count# 删除时返回文档对象 find_one_and_delete(filter, *args)

批量删除文档,调用方法:

result = db.COLLECTION_NAME.delete_many(filter, *args)# 返回已经删除的记录数result. deleted_count

示例代码:

# -*- coding: utf-8 -*-# @Time    : 2023-03-18 14:34# @Author  : AmoXiang# @File    : 3.删除文档.py# @Software: PyCharm# @Blog    : https://blog.csdn.net/xw1680from pymongo import MongoClientclass LearnMongoDBDelete(object):    """ MongoDB删除练习 """    def __init__(self):        self.client = MongoClient()    def test_delete_one(self):        """ 删除一个文档 """        db = self.client.get_database('test')        newdb = db.get_collection('newdb')        result = newdb.delete_one({})        print(result.deleted_count)    def test_delete_many(self):        """ 批量删除文档 """        db = self.client.get_database('test')        users = db.get_collection('newdb')        # 删除所有的数据        result = users.delete_many({"likes": {"$lte": 90}})        print(result.deleted_count)    def test_delete_shortcut(self):        """ 删除文档的快捷方法 """        db = self.client.get_database('test')        newdb = db.get_collection('newdb')        result = newdb.find_one_and_delete({})        print(result['title'])if __name__ == '__main__':    obj = LearnMongoDBDelete()    # obj.test_delete_one()    # obj.test_delete_shortcut()    obj.test_delete_many()

关于“Python怎么操作MongoDB数据库”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网Python频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: Python怎么操作MongoDB数据库

本文链接: https://www.lsjlt.com/news/352052.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python怎么操作MongoDB数据库
    这篇文章主要介绍“Python怎么操作MongoDB数据库”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python怎么操作MongoDB数据库”文章能帮助大家解决问题。一、连接器的安装和配置pym...
    99+
    2023-07-05
  • Python中怎么操作MongoDB数据库
    这期内容当中小编将会给大家带来有关Python中怎么操作MongoDB数据库,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、连接服务器连接服务器需要提供一个地址和接口import pymong...
    99+
    2023-06-15
  • 怎么用python包操作mongodb数据库
    本文小编为大家详细介绍“怎么用python包操作mongodb数据库”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用python包操作mongodb数据库”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、安...
    99+
    2023-06-30
  • Python中怎么操作MongoDB文档数据库
    Python中怎么操作MongoDB文档数据库,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.Pymongo 安装安装pymongo:pip install&nbs...
    99+
    2023-06-02
  • python 操作 mongodb 数据库详情
    目录一、安装二、连接数据库三、创建数据库四、所有数据库五、创建集合六、插入数据七、查询数据八、高级查询九、count统计十、修改数据十一、删除数据十二、数据排序一、安装 pip in...
    99+
    2022-11-10
  • 怎么操作mongodb数据库文件
    要操作MongoDB数据库文件,可以按照以下步骤进行操作:1. 安装MongoDB:首先,需要安装MongoDB数据库。你可以从Mo...
    99+
    2023-08-31
    mongodb数据库
  • Java中怎么操作MongoDB数据库
    今天就跟大家聊聊有关Java中怎么操作MongoDB数据库,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java与mongodb的连接1. 连单台m...
    99+
    2022-10-18
  • 如何用python 操作MongoDB数据库
    目录一、前言 二、操作 MongoDB 1、安装 pymongo 2、连接 MongoDB 3、选择数据库 4、选择集合 5、插入数据 6、查询 7、更新数据 8、删除 一...
    99+
    2022-11-12
  • MongoDB中怎么操作数据库文档
    MongoDB中怎么操作数据库文档,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。插入文档  要将数据插入到 Mong...
    99+
    2022-10-18
  • mongodb 数据库备份操作
    mongodb  数据库备份mongodump --host mongodb.example.net --port 27017备份路径选择mongodump --out /data/backup/...
    99+
    2022-10-18
  • mongoDB数据库基本操作
    mongoDB中聚集集合(collection/coll)相当于mysql中的表文档相当于mysql中的每一行数据常用命令 1.获得帮助命令db.help() db.表名.help() db.表名...
    99+
    2022-10-18
  • MongoDB(三):数据库操作、集合操作
    1. 数据库操作 看完前面的文章,大家应该把环境搭建好了,下面我们就开始学习MongoDB的一些基本操作了。 首先我们要了解的一些要点: MongoDB将数据存储为一个文档,数据结构由键值对(key=>value)组成 MongoDB文档...
    99+
    2017-03-01
    MongoDB(三):数据库操作 集合操作
  • Python 操作 MongoDB数据库的方法(非 ODM)
    目录一、连接器的安装和配置二、新增文档三、查询文档四、更新文档五、删除文档一、连接器的安装和配置 pymongo: MongoDB 官方提供的 python 工具包。官方文档: https://pymongo.readt...
    99+
    2023-03-19
    Python 操作 MongoDB
  • Python 操作 MongoDB数据库的方法(非 ODM)
    目录一、连接器的安装和配置二、新增文档三、查询文档四、更新文档五、删除文档一、连接器的安装和配置 pymongo: MongoDB 官方提供的 Python 工具包。官方文档: ht...
    99+
    2023-03-19
    Python 操作 MongoDB Python MongoDB
  • Node.js中怎么利用mongoose操作mongodb数据库
    本篇文章给大家分享的是有关Node.js中怎么利用mongoose操作mongodb数据库,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1.利...
    99+
    2022-10-19
  • Python怎么操作MongoDB
    这篇文章主要介绍Python怎么操作MongoDB,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1. 准备工作在开始之前,请确保已经安装好了MongoDB并启动了其服务,并且安装好了Python的PyMongo库。2...
    99+
    2023-06-28
  • python怎么操作redis数据库
    今天小编给大家分享一下python怎么操作redis数据库的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、安装redis ...
    99+
    2023-06-30
  • python怎么操作pymysql数据库
    本篇内容主要讲解“python怎么操作pymysql数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python怎么操作pymysql数据库”吧!一、安装pip install&n...
    99+
    2023-06-30
  • 使用Node怎么对MongoDB数据库进行操作
    这篇文章给大家介绍使用Node怎么对MongoDB数据库进行操作,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1.使用 MongoDB模块 进行操作 首先在工作目录安装 mo...
    99+
    2022-10-18
  • 利用Python操作MongoDB数据库的详细指南
    目录前言1 连接数据库1.1 安装PyMongo1.2 连接数据库1.3 连接库与集合2 MongoDB命令在python中的对应方法3 插入数据到MongoDB基本语法被插入的数据格式说明举例4 从MongoDB中查询...
    99+
    2022-06-24
    python操作mongodb数据库 python读取数据库数据 python 操作mongodb
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作