Python通过Sqlalchemy框架实现增删改查

目录

简介

什么是SQLAlchemy?

SQLAlchemy可以分为两个部分:Core和ORM。

一、首先安装sqlalchemy

二、在配置文件中添加数据库连接信息,我这里是Mysql

[三、 创建数据库连接类,我这里是动态读取数据库的表字段,自动生成实体model](#三、 创建数据库连接类,我这里是动态读取数据库的表字段,自动生成实体model)

四、验证


简介

什么是SQLAlchemy?

SQLAlchemy是一个Python的SQL工具和ORM框架,可以通过Python代码直接操作关系型数据库,也可以使用ORM模型进行对象关系映射。它支持多种数据库,并提供了强大的SQL表达式和查询API。

SQLAlchemy可以分为两个部分:CoreORM

Core: 提供了底层的SQL表达式和查询API,支持多种数据库的可移植操作,例如连接管理、事务管理、对象关系映射、元数据管理等。
ORM: 提供了基于Core的高级API,使得开发者可以使用Python的面向对象语法方式来进行数据库操作,把数据库表中的记录映射到Python中的对象实例上。ORM部分可以通过继承和关联来轻松进行数据关系的管理和维护,大大简化了数据库操作的难度。

以下是SQLAlchemy的一些优点:

可移植性: 支持多种数据库,并提供了统一的API,使得应用程序对于不同数据库的切换和迁移更加容易。
易用性: 提供了易用的API和强大的对象关系映射功能,开发者可以使用面向对象的方式来操作数据库,并且可以把数据库表中的记录映射到Python中的对象实例上。
易扩展性: SQLAchemy由活跃的开源社区维护,提供了完整的文档、教程和资料支持,可以方便地扩展和定制。

性能表现良好:SQLAlchemy在实现中采用了连接池管理连接,缓存查询结果等技术,以确保较高的性能和可伸缩性。

总之,SQLAlchemy是Python操作数据库的一个非常强大和优美的工具和框架,无论是从开发者的角度还是从性能方面考虑,都是一个非常不错的选择。

一、首先安装sqlalchemy

java 复制代码
pip install sqlalchemy

二、在配置文件中添加数据库连接信息,我这里是Mysql

三、 创建数据库连接类,我这里是动态读取数据库的表字段,自动生成实体model

python 复制代码
from sqlalchemy.ext.automap import automap_base
from sqlalchemy.orm import sessionmaker
from sqlalchemy import create_engine
from config.config import USERNAME,PASSWORD,HOSTNAME,DATABASE
from urllib import parse
# 创建基类
Base = automap_base()
# 替换以下 URL 为你的数据库连接字符串
PWD = parse.quote_plus(PASSWORD)
engine = create_engine('mysql+pymysql://{}:{}@{}/{}'.format(USERNAME,PWD,HOSTNAME,DATABASE))
# 映射已存在的表
Base.prepare(engine, reflect=True)

# 创建会话
Session = sessionmaker(bind=engine)
session = Session()


"""
这下面就可以根据表明直接生成实体Model了
"""
#字典表
DictionaryDO = Base.classes.mp_tb_z_dictionary
#秘钥表
keyDO = Base.classes.mp_tb_z_key

四、在主类引用可直接实现增删改查的操作

python 复制代码
from model.mysql_db_model import DictionaryDO ,keyDO,session


"""
测试专用
"""
@bi.route('/ssss', methods=['GET'])
def get_test():
    #查询
    DictionaryDOList = session.query(DictionaryDO).all()
    data = [
        {'id': dictionaryDO.id, 'type': dictionaryDO.type}  # 根据您的需求添加更多字段
        for dictionaryDO in DictionaryDOList
    ]
    
    #增删改查 。。。。。。等等操作
    
    
    return jsonify({
        "code": 0,
        "msg": "success",
        "data": data
    })

四、验证

postman访问结果:

相关推荐
会飞De琥珀11 分钟前
java工具类,字符串转时间
java·开发语言
小羊羔heihei24 分钟前
Python列表操作全攻略
经验分享·笔记·python·学习·其他·交友
源码潇潇和逸逸25 分钟前
独立部署高校圈子平台:PHP+UniApp打造社交+交易+服务一站式校园解决方案
开发语言·uni-app·php
2501_9083298527 分钟前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
LINgZone234 分钟前
深入解析:Cglib与JDK动态代理的实现原理、区别及性能对比
java·开发语言
一次旅行34 分钟前
今日心理学知识分享(三)
开发语言·javascript·程序人生·ecmascript
AI科技星1 小时前
光速螺旋量子几何统一场论——基于 v ≡ c 公理的四大基本力全维度求导证明与精准数值验证
c语言·开发语言·人工智能·算法·机器学习·平面
天天学IT1 小时前
第三章 Qt 编译及安装
开发语言·qt·qt教程·qt6教程
xyq20241 小时前
Window Memcached 安装指南
开发语言
牛十二1 小时前
openclaw安装mcporter搜索小红书
开发语言·javascript·ecmascript