当前位置:首页 > 文章列表 > 文章 > python教程 > Python SQLAlchemy 实战秘籍:从新手到专家

Python SQLAlchemy 实战秘籍:从新手到专家

来源:编程网 2024-03-17 08:45:26 0浏览 收藏

SQLAlchemy 是一款 Python 中强大的对象关系映射 (ORM) 工具,可轻松地将 Python 对象映射到数据库表。通过简单的 Python 代码,您可以轻松操作数据库,包括查询、插入、更新和删除。本文将介绍 SQLAlchemy 的基本和高级用法,包括关系映射、查询优化和事务管理。无论您是 SQLAlchemy 新手还是经验丰富的用户,本文都将为您提供宝贵的见解,帮助您充分利用这一强大工具。

Python SQLAlchemy 实战秘籍:从新手到专家

sqlAlchemy 简介

SQLAlchemy 是一款 python 中的开源对象关系映射(ORM工具,它可以帮助您轻松地将 Python 对象与数据库中的表进行映射,并通过简单的 Python 代码来对数据库进行操作。SQLAlchemy 支持多种数据库,包括 Mysqlpostgresql、SQLite 等。

SQLAlchemy 基本使用

1. 安装 SQLAlchemy

首先,您需要在您的 Python 环境中安装 SQLAlchemy。您可以使用以下命令进行安装:

pip install sqlalchemy

2. 创建数据库引擎

在使用 SQLAlchemy 之前,您需要先创建一个数据库引擎。数据库引擎是 SQLAlchemy 用于与数据库通信的接口。您可以使用以下代码来创建数据库引擎:

from sqlalchemy import create_engine

engine = create_engine("mysql+pymysql://user:passWord@host:port/database")

其中,mysql+pymysql 是数据库的类型,userpasswordhostportdatabase 分别是数据库的用户名、密码、主机、端口号和数据库名。

3. 创建会话

会话是 SQLAlchemy 用于与数据库交互的对象。您可以使用以下代码来创建会话:

Session = sessionmaker(bind=engine)
session = Session()

4. 操作数据库

您可以使用会话来对数据库进行各种操作,例如查询、插入、更新和删除。以下是一些常用的操作:

4.1 查询数据

您可以使用以下代码来查询数据:

results = session.query(User).filter(User.name == "John").all()

其中,User 是您要查询的表,filter() 方法用于过滤查询结果,all() 方法用于获取所有查询结果。

4.2 插入数据

您可以使用以下代码来插入数据:

new_user = User(name="John", age=30)
session.add(new_user)
session.commit()

其中,User 是您要插入数据的表,new_user 是您要插入的新数据,add() 方法用于将新数据添加到会话中,commit() 方法用于提交会话中的所有修改。

4.3 更新数据

您可以使用以下代码来更新数据:

user = session.query(User).filter(User.name == "John").first()
user.age = 31
session.commit()

其中,User 是您要更新数据的表,filter() 方法用于过滤查询结果,first() 方法用于获取第一个查询结果,age 是您要更新的字段,commit() 方法用于提交会话中的所有修改。

4.4 删除数据

您可以使用以下代码来删除数据:

user = session.query(User).filter(User.name == "John").first()
session.delete(user)
session.commit()

其中,User 是您要删除数据的表,filter() 方法用于过滤查询结果,first() 方法用于获取第一个查询结果,delete() 方法用于删除数据,commit() 方法用于提交会话中的所有修改。

SQLAlchemy 进阶使用

1. 关系映射

SQLAlchemy 可以帮助您轻松地将 Python 对象与数据库中的表进行映射。您可以使用以下代码来定义一个关系映射:

class User(Base):
__tablename__ = "user"

id = Column(Integer, primary_key=True)
name = Column(String(50), unique=True)
age = Column(Integer)

class Address(Base):
__tablename__ = "address"

id = Column(Integer, primary_key=True)
user_id = Column(Integer, ForeignKey("user.id"))
address = Column(String(100))

# 创建关系映射
User.addresses = relationship("Address", back_populates="user")
Address.user = relationship("User", back_populates="addresses")

其中,UserAddress 是您要映射的两个表,__tablename__ 属性指定了表的名称,id 属性指定了主键,nameageaddress 属性指定了表的字段。ForeignKey() 函数用于指定外键关系。relationship() 函数用于定义关系映射。

2. 查询优化

SQLAlchemy 提供了多种查询优化技术,可以帮助您提高查询性能。以下是一些常用的查询优化技术:

2.1 批量查询

您可以使用批量查询来提高查询性能。批量查询可以一次性查询多个数据行。您可以使用以下代码来进行批量查询:

users = session.query(User).filter(User.age > 18).all()

其中,User 是您要查询的表,filter() 方法用于过滤查询结果,all() 方法用于获取所有查询结果。

2.2 使用索引

您可以使用索引来提高查询性能。索引可以帮助数据库快速找到您要查询的数据。您可以使用以下代码来创建索引:

session.execute("CREATE INDEX idx_user_age ON user (age)")

其中,user 是您要创建索引的表,age 是您要创建索引的字段。

3. 事务管理

SQLAlchemy 支持事务管理。事务可以帮助您确保数据库操作要么全部成功,要么全部失败。您可以使用以下代码来开启一个事务:

session.begin()

您可以使用以下代码来提交一个事务:

session.commit()

您可以使用以下代码来回滚一个事务:

session.rollback()

结语

SQLAlchemy 是一个功能强大且易于使用的 ORM 工具。它可以帮助您轻松地将 Python 对象与数据库中的表进行映射,并通过简单的 Python 代码来对数据库进行操作。本文介绍了 SQLAlchemy 的基本使用和进阶使用。希望您能通过本文学习到 SQLAlchemy 的使用技巧,并将其应用到您的实际项目中。

本篇关于《Python SQLAlchemy 实战秘籍:从新手到专家》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

版本声明
本文转载于:编程网 如有侵犯,请联系study_golang@163.com删除
Go代码在本地环境运行结果与go play中运行结果不一样Go代码在本地环境运行结果与go play中运行结果不一样
上一篇
Go代码在本地环境运行结果与go play中运行结果不一样
Python如何为区块链开发者提供竞争优势?
下一篇
Python如何为区块链开发者提供竞争优势?
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 毕业宝AIGC检测:AI生成内容检测工具,助力学术诚信
    毕业宝AIGC检测
    毕业宝AIGC检测是“毕业宝”平台的AI生成内容检测工具,专为学术场景设计,帮助用户初步判断文本的原创性和AI参与度。通过与知网、维普数据库联动,提供全面检测结果,适用于学生、研究者、教育工作者及内容创作者。
    23次使用
  • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
    AI Make Song
    AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
    33次使用
  • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
    SongGenerator
    探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
    30次使用
  •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
    BeArt AI换脸
    探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
    33次使用
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    36次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码