python中SQLAlchemy是什么?

冷炫風刃
发布: 2025-11-21 12:56:02
原创
468人浏览过
ORM是对象关系映射,将数据库表映射为Python类,行转为对象,字段转属性。SQLAlchemy通过Engine连接数据库,Session操作数据,Base定义模型。例如创建User类对应users表,用session.add()插入数据,无需手写SQL。支持多数据库,提升开发效率与维护性,常用于Flask、FastAPI等框架。

python中sqlalchemy是什么?

SQLAlchemy 是 Python 中一个强大的 ORM(对象关系映射) 库,它让开发者可以用 Python 类和对象的方式来操作数据库,而不必直接写 SQL 语句。简单来说,你可以用面向对象的方式处理数据库中的表和记录。

什么是 ORM?

ORM 的全称是 Object-Relational Mapping(对象关系映射)。它把数据库中的表映射成 Python 类,表的每一行数据对应类的一个实例(对象),字段则对应对象的属性。这样你就可以用 Python 代码来增删改查数据,SQLAlchemy 会自动帮你转换成对应的 SQL 操作。

例如:

如果你有一个用户表 users,传统方式你要写:

立即学习Python免费学习笔记(深入)”;

INSERT INTO users (name, age) VALUES ('Alice', 25);
登录后复制

用 SQLAlchemy,你可以这样写:

新鲜水果网站销售模板
新鲜水果网站销售模板

网站模板是能够具有交互性,能够包含更多活跃的元素,就有必要在网页中嵌入其它的技术。如:Javascript、VBScript、Document Object Model(DOM,文档对象模型)、Layers和 Cascading Style Sheets(CSS,层叠样式表),这里主要讲Javascript。那么Javascript是什么东西?Javascript就是适应动态网页制作的需要而诞生的

新鲜水果网站销售模板 70
查看详情 新鲜水果网站销售模板
user = User(name='Alice', age=25)
session.add(user)
session.commit()
登录后复制

看起来更像在操作 Python 对象,而不是数据库。

SQLAlchemy 的核心组件

  • Engine:连接数据库的入口,负责管理连接池和与数据库通信。
  • Session:用于操作数据库中的数据,比如添加、查询、删除对象。
  • Base / declarative_base():所有模型类的基类,用来定义数据表结构。
  • Model(模型类):继承 Base 的类,每个类对应一张数据库表。

常见用途和优势

  • 减少手写 SQL 的工作量,提高开发效率。
  • 代码更易维护,尤其是项目大了以后。
  • 支持多种数据库(如 SQLite、MySQL、PostgreSQL 等),切换数据库时改动小。
  • 可以灵活地混合使用 ORM 和原生 SQL,适合复杂查询。

一个简单例子

下面是一个使用 SQLAlchemy 创建用户表并插入数据的示例:

from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
<h1>创建引擎</h1><p>engine = create_engine('sqlite:///example.db')
Base = declarative_base()</p><h1>定义模型</h1><p>class User(Base):
<strong>tablename</strong> = 'users'
id = Column(Integer, primary_key=True)
name = Column(String(50))
age = Column(Integer)</p><h1>创建表</h1><p>Base.metadata.create_all(engine)</p><h1>创建会话</h1><p>Session = sessionmaker(bind=engine)
session = Session()</p><h1>添加用户</h1><p>new_user = User(name='Bob', age=30)
session.add(new_user)
session.commit()</p><h1>查询用户</h1><p>for user in session.query(User).filter_by(name='Bob'):
print(user.name, user.age)
登录后复制

基本上就这些。SQLAlchemy 不仅功能强大,还被广泛用于 Flask、FastAPI 等 Web 框架中进行数据库操作。掌握它对做后端开发很有帮助。

以上就是python中SQLAlchemy是什么?的详细内容,更多请关注php中文网其它相关文章!

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号