Python中的SQL数据库管理:SQLAlchemy教程


Python中的SQL数据库管理:SQLAlchemy教程

在Python应用程序中,操作数据库是常见的需求之一。而 SQLAlchemy 是一个功能强大的数据库管理库,它提供了Pythonic的接口来管理和查询SQL数据库。SQLAlchemy 兼具 ORM(对象关系映射)和核心 SQL 表达式构建功能,让用户既能享受面向对象的操作,也能灵活地编写复杂的 SQL 查询。本文将带您一步步了解 SQLAlchemy 的使用方式和常用技巧,帮助您在Python中高效管理SQL数据库。

一、SQLAlchemy 简介

SQLAlchemy 可以分为两个主要部分:

  • SQLAlchemy Core:一个轻量级的SQL表达式语言,支持基本的SQL查询构建。
  • SQLAlchemy ORM:基于对象关系映射的ORM库,允许我们将数据库表与Python对象关联,通过操作对象来操作数据库表。

安装 SQLAlchemy

要使用 SQLAlchemy,首先确保安装最新版本:

pip install sqlalchemy

二、创建数据库引擎

SQLAlchemy 的数据库连接是通过 Engine 对象实现的。连接数据库时,只需提供数据库URL,SQLAlchemy 将会自动选择相应的数据库驱动。

from sqlalchemy import create_engine

# SQLite 示例数据库
engine = create_engine('sqlite:///example.db')

常见的数据库URL格式

  • SQLite: sqlite:///example.db
  • PostgreSQL: postgresql://username:password@localhost:5432/mydatabase
  • MySQL: mysql+pymysql://username:password@localhost/mydatabase

三、定义表结构

1. 使用 SQLAlchemy Core 定义表

可以通过 Table 对象定义表结构,包含表名、字段类型和主键等信息:

from sqlalchemy import MetaData, Table, Column, Integer, String

metadata = MetaData()

users = Table(
    'users', metadata,
    Column('id', Integer, primary_key=True),
    Column('name', String, nullable=False),
    Column('age', Integer)
)

2. 使用 ORM 定义表和模型

SQLAlchemy ORM 允许我们用 Python 类表示数据库中的表,定义一个模型类并继承 Base,通过字段类型定义表的结构。

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String

Base = declarative_base()

class User(Base):
    __tablename__ = 'users'

    id = Column(Integer, primary_key=True)
    name = Column(String, nullable=False)
    age = Column(Integer)

# 创建所有定义的表
Base.metadata.create_all(engine)

四、建立会话并操作数据库

要操作数据库,需要通过 Session 对象与数据库交互。Session 提供了事务管理的功能,是 ORM 的核心部分。

from sqlalchemy.orm import sessionmaker

# 创建Session类
Session = sessionmaker(bind=engine)
session = Session()

1. 插入数据

通过 ORM 模型实例化对象后,可以使用 session.add()session.add_all() 插入一条或多条数据。

# 创建一个新用户
new_user = User(name="Alice", age=25)
session.add(new_user)
session.commit()  # 提交更改

2. 查询数据

SQLAlchemy 提供了多种查询方法,如 query()filter() 等,让我们可以方便地进行各种复杂查询。

# 查询所有用户
users = session.query(User).all()
for user in users:
    print(user.name, user.age)

# 查询单个用户
user = session.query(User).filter_by(name="Alice").first()
print(user.name, user.age)

3. 更新数据

通过查询获取对象后,直接修改对象的属性并提交即可完成更新。

user = session.query(User).filter_by(name="Alice").first()
user.age = 30
session.commit()

4. 删除数据

使用 session.delete() 删除数据,删除后需要提交更改。

user = session.query(User).filter_by(name="Alice").first()
session.delete(user)
session.commit()

五、高级查询技巧

SQLAlchemy 提供了丰富的查询 API,支持复杂查询操作,例如排序、分组、连接等。

1. 排序和限制

可以使用 order_by()limit() 方法实现结果排序和限制结果数量。

# 按年龄降序排序,获取前 5 个用户
users = session.query(User).order_by(User.age.desc()).limit(5).all()

2. 分组查询

可以使用 group_by() 实现分组查询,并结合 func 模块进行聚合计算。

from sqlalchemy import func

# 查询每个年龄段的用户数量
age_count = session.query(User.age, func.count(User.id)).group_by(User.age).all()

3. 多表连接查询

在多表关联查询中,可以使用 join() 函数连接表,例如通过用户 ID 在 orders 表中查找用户订单。

# 假设有一个 Orders 表,我们可以通过 User 表和 Orders 表的关系进行连接查询
orders = session.query(User, Order).join(Order, User.id == Order.user_id).all()

六、使用事务管理

在 SQLAlchemy 中,事务是通过 Session 管理的。操作数据时可以使用 commit() 提交事务,也可以使用 rollback() 回滚事务。在批量操作数据时,通常使用事务块来确保操作的原子性。

# 开启事务
try:
    user = User(name="Bob", age=22)
    session.add(user)
    session.commit()
except Exception as e:
    session.rollback()  # 出错时回滚事务
    print(f"发生错误: {e}")
finally:
    session.close()

七、模型间关系管理

在 ORM 中,我们可以通过关系(relationship)来定义模型之间的关联,如一对多或多对多关系。SQLAlchemy 提供了 relationship() 方法进行关联映射。

1. 一对多关系

假设我们有一个 UserPost 表,每个用户可以有多个帖子,可以定义一对多的关系。

from sqlalchemy.orm import relationship

class Post(Base):
    __tablename__ = 'posts'
    
    id = Column(Integer, primary_key=True)
    title = Column(String, nullable=False)
    user_id = Column(Integer, ForeignKey('users.id'))

    user = relationship("User", back_populates="posts")

class User(Base):
    __tablename__ = 'users'
    
    id = Column(Integer, primary_key=True)
    name = Column(String, nullable=False)
    age = Column(Integer)
    
    posts = relationship("Post", back_populates="user")

2. 多对多关系

假设有一个 StudentCourse 表,可以使用 association_table 创建中间表来定义多对多的关系。

association_table = Table(
    'student_course', Base.metadata,
    Column('student_id', Integer, ForeignKey('students.id')),
    Column('course_id', Integer, ForeignKey('courses.id'))
)

class Student(Base):
    __tablename__ = 'students'
    id = Column(Integer, primary_key=True)
    name = Column(String)
    courses = relationship("Course", secondary=association_table, back_populates="students")

class Course(Base):
    __tablename__ = 'courses'
    id = Column(Integer, primary_key=True)
    title = Column(String)
    students = relationship("Student", secondary=association_table, back_populates="courses")

八、总结

SQLAlchemy 是一个功能强大的数据库管理库,为 Python 开发者提供了操作 SQL 数据库的高效方式。通过 SQLAlchemy,您可以轻松地进行表定义、数据插入、复杂查询、事务管理和关系管理等操作。本教程涵盖了 SQLAlchemy 的基础与进阶使用方法,希望对您在实际开发中的数据库管理有所帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/906539.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring IoC——依赖注入

1. 依赖注入的介绍 DI,也就是依赖注入,在容器中建立的 bean (对象)与 bean 之间是有依赖关系的,如果直接把对象存在 IoC 容器中,那么就都是一个独立的对象,通过建立他们的依赖关系,…

IDEA连接EXPRESS版本的SQL server数据库

我安装的版本是SQL2019-SSEI-Expr.exe 也就是EXPRESS版本的SQL Server安排非常简单和快速。 但是默认没有启动sa用户。 启动sa用户名密码登录 默认安装完以后没有启用。 使用Miscrosoft SQL Server Management Studio 使用Windows身份连接后。 在安全性》登录名中找到sa并修改…

​Java面试经典 150 题.P13. 罗马数字转整数(012)​

本题来自:力扣-面试经典 150 题 面试经典 150 题 - 学习计划 - 力扣(LeetCode)全球极客挚爱的技术成长平台https://leetcode.cn/studyplan/top-interview-150/ 题解: class Solution {public int romanToInt(String s) {int sum…

大数据-204 数据挖掘 机器学习理论 - 混淆矩阵 sklearn 决策树算法评价

点一下关注吧!!!非常感谢!!持续更新!!! 目前已经更新到了: Hadoop(已更完)HDFS(已更完)MapReduce(已更完&am…

Windows11下将某个程序添加到鼠标右键快捷菜单

经常看log,最喜欢用的txt查看和编辑工具是EditPlus,好像是个韩国软件,最大的优势是打开大文件,好几G的log文件也很轻松,速度快,然后还有各种高亮设置查找文件等,非常方便。但是不知道为什么&…

宏处理将多个excel文件的指定sheet页合并到一个excel文件中

背景了解:有个同事问我:现在他要处理一千多个文件,每个excel文件都有3个sheet页签,想把所有的excel文件的第二个sheet页签复制一份放到一个新的excel文件中。如果是手动去操作一个个文件的复制,也没什么不可&#xff0…

什么是散度,什么是旋度,分别反映什么现象,磁场和静电场分别是什么场?

散度和旋度是矢量场中重要的微分运算概念,用来描述矢量场的局部特性,广泛应用于物理学、流体力学和电磁学中。 1. 散度(Divergence) 散度描述的是一个矢量场在某一点的“发散”或“汇聚”程度,简单来说就是在该点附近…

web——warmup——攻防世界

这道题还是没有做出来。。,来总结一下 1.ctrlU显示源码 2.看见body里有source.php 打开这个source.php 看见了源码 highlight_file(FILE); 这行代码用于高亮显示当前文件的源码,适合调试和学习,但在生产环境中通常不需要。 class emmm 定义…

vue3项目history模式部署404处理,使用 historyApiFallback 中间件支持单页面应用路由

vue3项目history模式部署404处理,使用 historyApiFallback 中间件支持单页面应用路由 在现代的 web 开发中,单页面应用(SPA)变得越来越流行。这类应用通常依赖于客户端路由来提供流畅的用户体验,但在服务器端&#xf…

跨境电商平台系统开发

随着全球化的不断深入,跨境电商作为新兴的商业模式,越来越受到企业和消费者的关注。跨境电商平台的系统开发不仅涉及技术层面的挑战,更涉及到法律、物流、支付等多方面的因素。商淘云将分享跨境电商平台系统开发的主要环节,包括需…

《Web性能权威指南》-WebRTC-读书笔记

本文是《Web性能权威指南》第四部分——WebRTC的读书笔记。 第一部分——网络技术概览,请参考网络技术概览; 第二部分——无线网络性能,请参考无线网络性能; 第三部分——HTTP,请参考HTTP; 第四部分——浏览…

.NET 8 Web API 中的身份验证和授权

本次介绍分为3篇文章: 1:.Net 8 Web API CRUD 操作.Net 8 Web API CRUD 操作-CSDN博客 2:在 .Net 8 API 中实现 Entity Framework 的 Code First 方法https://blog.csdn.net/hefeng_aspnet/article/details/143229912 3:.NET …

android定时器循环实现轮播图

说明: android定时器加for循环实现轮播图 效果: step1: package com.example.iosdialogdemo;import android.os.Bundle; import android.os.Handler; import android.widget.ImageView; import android.widget.TextView;import androidx.appcompat.ap…

基于Node.js+Vue+MySQL实现的(Web)图书管理系统

1 需求分析 本图书管理系统主要实现对图书馆的管理:图书、读者、管理员、借阅。由此,结构可分为:图书管理、读者管理、管理员管理、借还管理、罚单管理、还书信息。 1.1 需求定义 1.1.1 图书管理 可对图书信息进行浏览、编辑(…

计算机网络803-(5)运输层

目录 一.运输层的两个主要协议:TCP 与 UDP 1.TCP/IP 的运输层有两个不同的协议: 2.端口号(protocol port number) (1)软件端口与硬件端口 (2)TCP 的端口 (3)三类端口 二.用户…

机器学习之fetch_olivetti_faces人脸识别--基于Python实现

fetch_olivetti_faces 数据集下载 fetch_olivetti_faceshttps://github.com/jikechao/olivettifaces sklearn.datasets.fetch_olivetti_faces(*, data_homeNone, shuffleFalse, random_state0, download_if_missingTrue, return_X_yFalse, n_retries3, delay1.0)[source] L…

嵌入式硬件电子电路设计(三)电源电路之负电源

引言:在对信号线性度放大要求非常高的应用需要使用双电源运放,比如高精度测量仪器、仪表等;那么就需要给双电源运放提供正负电源。 目录 负电源电路原理 负电源的作用 如何产生负电源 负电源能作功吗? 地的理解 负电压产生电路 BUCK电…

【SpringMVC】传递json,获取url参数,上传文件

【传递json数据】 【json概念】 一种轻量级数据交互格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,其本质上是字符串,负责在不同的语言中数据传递与交换 json数据以字符串的形式体现 【json字符串与Java对象互转…

web3.0 开发实践

优质博文:IT-BLOG-CN 一、简介 Web3.0也称为去中心化网络,是对互联网未来演进的一种概念性描述。它代表着对现有互联网的下一代版本的设想和期望。Web3.0的目标是通过整合区块链技术、分布式系统和加密技术等新兴技术,构建一个更加去中心化…

10.31.2024刷华为OD C题型

文章目录 HJ26HJ27语法知识记录 10.24.2024刷华为OD C题型(四) - HJ26 HJ27 def get_dict(str1: str):dic_0 {}for ch in str1:if ch not in dic_0:dic_0[ch] 1else:dic_0[ch] 1return dic_0temp input().split() n int(temp[0]) list [] for i in range(n):l…