【Python数据库】MongoDB

### 文章目录

  • [@[toc]](#文章目录 @[toc] 数据插入 数据查询 数据更新 数据删除)
  • [数据插入](#文章目录 @[toc] 数据插入 数据查询 数据更新 数据删除)
  • [数据查询](#文章目录 @[toc] 数据插入 数据查询 数据更新 数据删除)
  • [数据更新](#文章目录 @[toc] 数据插入 数据查询 数据更新 数据删除)
  • [数据删除](#文章目录 @[toc] 数据插入 数据查询 数据更新 数据删除)

个人主页:丷从心·

系列专栏:Python数据库

学习指南:Python学习指南


数据插入

python 复制代码
from pymongo import MongoClient


def insert_data():
    mongo_client = MongoClient(host='localhost', port=27017)
    collection = mongo_client['python_database']['book_info']

    try:
        collection.insert_many([{'id': 1, 'name': '射雕英雄传', 'pub_date': '1980-5-1', 'read_count': 12,
                                 'comment_count': 34, 'is_delete': 0},
                                {'id': 2, 'name': '天龙八部', 'pub_date': '1986-7-24', 'read_count': 36,
                                 'comment_count': 40, 'is_delete': 0},
                                {'id': 3, 'name': '笑傲江湖', 'pub_date': '1995-12-24', 'read_count': 20,
                                 'comment_count': 80, 'is_delete': 0},
                                {'id': 4, 'name': '雪山飞狐', 'pub_date': '1987-11-11', 'read_count': 58,
                                 'comment_count': 24, 'is_delete': 0}])
    except Exception as e:
        print(f'数据插入失败: {e}')
    else:
        print('数据插入成功...')


if __name__ == '__main__':
    insert_data()
  • mongo_client = MongoClient(host='localhost', port=27017)用于连接数据库

    • host用于指定数据库IP地址,localhost表示本地
    • port用于指定数据库端口
  • collection = mongo_client['python_database']['book_info']用于指定数据库和数据集合

    • 'python_database'是指定的数据库
    • 'book_info'是指定的数据集合
  • collection.insert_many()用于插入多条数据


数据查询

python 复制代码
from pymongo import MongoClient


def query_data():
    mongo_client = MongoClient(host='localhost', port=27017)
    collection = mongo_client['python_database']['book_info']

    result = collection.find_one({'name': '射雕英雄传'})
    if result:
        print(result)
    else:
        print('数据不存在...')


if __name__ == '__main__':
    query_data()

数据更新

python 复制代码
from pymongo import MongoClient


def update_data():
    mongo_client = MongoClient(host='localhost', port=27017)
    collection = mongo_client['python_database']['book_info']

    collection.update_one({'name': '射雕英雄传'}, {'$set': {'is_delete': 1}})

    result = collection.find_one({'name': '射雕英雄传'})
    if result:
        print(result)
    else:
        print('数据不存在...')


if __name__ == '__main__':
    update_data()

数据删除

python 复制代码
from pymongo import MongoClient


def delete_data():
    mongo_client = MongoClient(host='localhost', port=27017)
    collection = mongo_client['python_database']['book_info']

    collection.delete_one({'name': '射雕英雄传'})

    result = collection.find()
    if result:
        for item in result:
            print(item)
    else:
        print('数据不存在...')


if __name__ == '__main__':
    delete_data()

相关推荐
fengxin_rou2 分钟前
一文读懂 Redis 集群:从哈希槽到透明访问
java·数据库·redis·算法·spring·缓存
m0_635647484 分钟前
Qt开发与MySQL数据库教程(二)——MySQL常用命令以及示例
java·开发语言·数据库·mysql
顶点多余6 分钟前
数据库——对表的操作
数据库
程序员榴莲8 分钟前
MySQL (一):MySQL的安装与启动
数据库·mysql
咖啡の猫16 分钟前
Redis 通用命令
数据库·redis·bootstrap
IT界的老黄牛25 分钟前
【IT老齐230 笔记 + 思考】金融业容灾方案“两地三中心“是什么意思?
数据库·笔记·架构
aiAIman25 分钟前
OpenClaw 用户必修课:(三)Claude Code 单一聊天原则、Hooks 与 LSP
数据库·人工智能·开源·aigc
所谓伊人,在水一方33327 分钟前
【Python数据科学实战之路】第5章 | 数据可视化基础:用Matplotlib讲好数据故事
python·信息可视化·matplotlib
oradh32 分钟前
Oracle单库环境下计划内启停数据库的步骤
数据库·oracle
DolphinDB智臾科技32 分钟前
2026 工业时序数据库选型指南:抽象复用能力如何降低 80% 开发成本——DolphinDB vs InfluxDB/TimescaleDB 深度对比与实践
数据库·物联网·时序数据库·dolphindb