【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()

相关推荐
灵智工坊LingzhiAI6 分钟前
人体坐姿检测系统项目教程(YOLO11+PyTorch+可视化)
人工智能·pytorch·python
Hello.Reader3 小时前
Redis 延迟监控深度指南
数据库·redis·缓存
ybq195133454313 小时前
Redis-主从复制-分布式系统
java·数据库·redis
好奇的菜鸟6 小时前
如何在IntelliJ IDEA中设置数据库连接全局共享
java·数据库·intellij-idea
tan180°6 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
满昕欢喜6 小时前
SQL Server从入门到项目实践(超值版)读书笔记 20
数据库·sql·sqlserver
Hello.Reader8 小时前
Redis 延迟排查与优化全攻略
数据库·redis·缓存
烛阴8 小时前
简单入门Python装饰器
前端·python
好开心啊没烦恼8 小时前
Python 数据分析:numpy,说人话,说说数组维度。听故事学知识点怎么这么容易?
开发语言·人工智能·python·数据挖掘·数据分析·numpy
面朝大海,春不暖,花不开8 小时前
使用 Python 实现 ETL 流程:从文本文件提取到数据处理的全面指南
python·etl·原型模式