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

相关推荐
IndulgeCui1 分钟前
KES集群部署安装问题记录
数据库
BoBoZz193 分钟前
AlignTwoPolyDatas 基于ICP算法的配准和相机视角切换
python·vtk·图形渲染·图形处理
Yilena6 分钟前
通过mysqldump进行数据迁移时权限不足的解决方案
数据库·学习
韩立学长13 分钟前
基于Springboot酒店管理系统的设计与实现c12044zy(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
han_hanker14 分钟前
统一拦截异常 @RestControllerAdvice
java·开发语言·数据库
嗝o゚15 分钟前
Flutter与开源鸿蒙:一场“应用定义权”的静默战争,与开发者的“范式跃迁”机会
python·flutter
一只会奔跑的小橙子18 分钟前
pytest安装对应的库的方法
python
ohoy30 分钟前
EasyPoi 数据脱敏
开发语言·python·excel
BoBoZz1932 分钟前
MarchingCubes 网格数据体素化并提取等值面
python·vtk·图形渲染·图形处理
herinspace36 分钟前
管家婆软件年结存后快马商城操作注意事项
服务器·数据库·windows