SQLAlchemy系列教程:理解SQLAlchemy元数据

SQLAlchemy是Python开发人员的强大ORM工具。SQLAlchemy中的元数据是对象-关系映射配置的集合,允许开发人员无缝地定义和使用数据库模式。
在这里插入图片描述

使用元数据

SQLAlchemy中的元数据充当各种数据库描述符(如表、列和索引)的容器。这使开发人员能够通过高级Python构造生成和管理数据库结构。让我们通过实际示例探索如何在SQLAlchemy中使用元数据。

基本用法

from sqlalchemy import MetaData, Table, Column, Integer, Stringmetadata = MetaData()
users_table = Table('users', metadata,Column('id', Integer, primary_key=True),Column('name', String)
)

在上面的代码片段中,我们在MetaData实例中创建了一个Table对象,定义了一个带有ID和名称的简单users表。

抽取现有数据库模式

from sqlalchemy import create_engine, MetaDataengine = create_engine('sqlite:///example.db')
metadata = MetaData()
metadata.reflect(bind=engine)for table_name in metadata.tables:print(table_name)

这个示例演示了如何将现有数据库模式加载到元数据对象中,以便在SQLAlchemy中进行自省或交互。

定义关系

from sqlalchemy import ForeignKeyaddresses_table = Table('addresses', metadata,Column('id', Integer, primary_key=True),Column('user_id', None, ForeignKey('users.id')),Column('email', String, nullable=False)
)

在这里,我们定义了用户和地址之间的一对多关系,其中每个地址通过外键与用户相关联。

SQLAlchemy使用元数据

from sqlalchemy.orm import mapper, sessionmakerclass User(object):passmapper(User, users_table)
Session = sessionmaker(bind=engine)
session = Session()new_user = User()
new_user.id = 1
new_user.name = 'John Doe'
session.add(new_user)
session.commit()

上面的例子将一个Python类映射到定义的users表,并演示了使用ORM会话插入一条新记录。

mapper 的作用:
  • 对象关系映射(ORM)mapper 函数用于将 Python 类(如 User)与数据库表(如 users_table)进行映射。这样,你可以通过操作 Python 对象来间接操作数据库表中的数据。
  • 属性关联:通过映射,User 类的实例将对应 users 表中的行,类的属性(如 idname)将对应表的列。
现代 SQLAlchemy 的推荐做法:

在现代 SQLAlchemy(版本 1.4 及以上)中,推荐使用 Declarative 扩展来进行 ORM 映射,而不是直接使用 mapper。Declarative 提供了更简洁和直观的方式来定义模型类。

使用 Declarative 的示例:

from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.orm import declarative_base, sessionmakerBase = declarative_base()class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)name = Column(String)# 创建引擎和会话
engine = create_engine('sqlite:///example.db', echo=True)
Session = sessionmaker(bind=engine)
session = Session()

这种方式自动处理了映射过程,减少了样板代码,使代码更简洁易读。

高级元数据用法

可以自定义SQLAlchemy的元数据,以利用命名约定、显式模式和高级数据类型。它还可以用于动态生成表和查询元数据属性。

metadata = MetaData(naming_convention={"ix": 'ix_%(column_0_label)s',"uq": "uq_%(table_name)s_%(column_0_name)s","ck": "ck_%(table_name)s_%(constraint_name)s","fk": "fk_%(table_name)s_%(column_0_name)s_%(referred_table_name)s","pk": "pk_%(table_name)s"
})

这个例子展示了索引、唯一约束、检查约束、外键和主键的自定义命名约定。

从元数据生成DDL

metadata.create_all(engine)

create_all方法为元数据实例中包含的所有表和约束向数据库发出适当的DDL命令。

实战案例

在实际项目中,使用 SQLAlchemy 进行数据库操作时,以下是一些最佳实践:

a. 使用 Declarative 定义模型

如上所示,使用 Declarative 扩展定义模型类,不仅简化了代码,还提高了可维护性。

b. 分离模型、数据库引擎和会话管理

将模型定义、数据库引擎的创建和会话管理分离到不同的模块中,有助于组织代码,增强可重用性和可测试性。

示例结构:

project/
│
├── models.py          # 定义模型类
├── database.py        # 创建引擎和会话
└── main.py            # 主程序逻辑

models.py:

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, StringBase = declarative_base()class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)name = Column(String)

database.py:

from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from models import BaseDATABASE_URL = "sqlite:///example.db"engine = create_engine(DATABASE_URL, echo=True)
SessionLocal = sessionmaker(bind=engine)def init_db():Base.metadata.create_all(bind=engine)

main.py:

from database import SessionLocal, init_db
from models import Userdef main():init_db()session = SessionLocal()new_user = User(name='John Doe')session.add(new_user)session.commit()session.close()if __name__ == "__main__":main()

一般开发阶段通过init_db()创建表,在生产环境中,建议在部署脚本或初始化流程中手动创建表,以确保数据库结构的可控性和一致性。此外,可以使用迁移工具(如 Alembic)来管理数据库模式的变更。

最后总结

SQLAlchemy Metadata提供了一个健壮的接口,可以在Python环境中处理数据库的模式。通过提供的示例,我们探索了元数据的基本概念,以及如何利用它们来简化数据库操作。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Soul 1.4.60 | 清爽版浏览器,内置广告拦截与多功能集成,保护隐私

Soul浏览器是一款专注于内容浏览体验的安卓浏览器,去除广告与追踪器,集成视频下载、PDF查看、手势控制等实用功能。支持无痕模式与黑暗主题,内置清洁器自动过滤广告,优化网页加载速度,提供流畅的浏览体验与隐私保护。支…

最短路问题

Problem - D - Codeforces(最短路,反向bfs) 题目: 思路: bfs版本:参考自Codeforces Round 1002 (Div. 2) A - D - 知乎 代码: dijstra: void solve() {int n;cin>>n;int s…

【论文阅读】多模态——LSeg

文献基本信息 标题:Language-Driven Semantic Segmentation作者:Boyi Li、Kilian Q. Weinberger、Serge Belongie、Vladlen Koltun、Ren Ranftl单位:Cornell University、University of Copenhagen、Apple、Intel Labs会议/期刊:…

Docker Desktop常见问题记录

1.docker pull报错,无法连接https://registry-1.docker.io/v2/ 报错信息如下: Error response from daemon: Get "https://registry-1.docker.io/v2/": net/http: request canceled while waiting for connection(Client.Timeout exceeded …

Java 大视界 -- Java 大数据在智能政务公共服务资源优化配置中的应用(118)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

Python快捷手册

Python快捷手册 后续会陆续更新Python对应的依赖或者工具使用方法 文章目录 Python快捷手册[toc]1-依赖1-词云小工具2-图片添加文字3-BeautifulSoup网络爬虫4-Tkinter界面绘制5-PDF转Word 2-开发1-多线程和队列 3-运维1-Requirement依赖2-波尔实验室3-Anaconda3使用教程4-CentO…

Javaweb后端spring事务管理 事务四大特性ACID

2步操作,只能同时成功,同时失败,要放在一个事务中,最后提交事务或者回滚事务 事务控制 事务管理进阶 事务的注解 这是所有异常都会回滚 事务注解 事务的传播行为 四大特性

AI绘画软件Stable Diffusion详解教程(2):Windows系统本地化部署操作方法(专业版)

一、事前准备 1、一台配置不错的电脑,英伟达显卡,20系列起步,建议显存6G起步,安装win10或以上版本,我的显卡是40系列,16G显存,所以跑大部分的模型都比较快; 2、科学上网&#xff0…

光伏电池输出功率模型

1.光伏电池输出功率 1.1光伏电池的效率 温度对光伏电池/组件电效率的影响可以追溯到温度对电流I和电压V的影响,因为最大功率表达式为: 其中,Pm为最大输出功率;Vm为最大输出功率点电压;Im为最大输出功率点电流&#xf…

【大模型基础_毛玉仁】1.4 语言模型的采样方法

【大模型基础_毛玉仁】1.4 语言模型的采样方法 1.4 语言模型的采样方法1.4.1 概率最大化方法1)贪心搜索(GreedySearch)2)波束搜索(BeamSearch) 1.4.2 随机采样方法1)Top-K 采样2)Top…

MyBatis - XML CRUD 其他查询

1. XML 配置文件 使用 MyBatis 操作数据库的方式有两种: 注解 (在注解中定义 SQL 语句)XML 配置文件 (在 XML 文件中定义 SQL 语句) 在上一篇博客中, 已经讲解了如何使用注解操作数据库, 本篇文章来讲解如何使用 XML 进行 MyBatis 开发. 使用 XML 的步骤, 和使用注解的步骤…

DeepSeek + 飞书多维表格搭建你的高效工作流

众所周知,大模型DeepSeek擅长于处理大规模语言模型推理任务,特别是在成本降低和思维链推理方面表现出色‌,我们一般把大模型必做我们的大脑,但是一个人不能只有大脑,还需要其他输入输出以及操作支配的眼耳鼻嘴手足等。…

跨域-告别CORS烦恼

跨域-告别CORS烦恼 文章目录 跨域-告别CORS烦恼[toc]1-参考网址2-思路整理1-核心问题2-个人思考3-脑洞打开4-个人思考-修正版1-个人思考2-脑洞打开 3-知识整理1-什么是跨域一、同源策略简介什么是源什么是同源是否是同源的判断哪些操作不受同源策略限制跨域如何跨域 二、CORS 简…

基于Django创建一个WEB后端框架(DjangoRestFramework+MySQL)流程

一、Django项目初始化 1.创建Django项目 Django-admin startproject 项目名 2.安装 djangorestframework pip install djangorestframework 解释: Django REST Framework (DRF) 是基于 Django 框架的一个强大的 Web API 框架,提供了多种工具和库来构建 RESTf…

基于多目标向日葵优化算法(Multi-objective Sunflower Optimization,MOSFO)的移动机器人路径规划研究,MATLAB代码

一、机器人路径规划介绍 移动机器人路径规划是机器人研究的重要分支,是对其进行控制的基础。根据环境信息的已知程度不同,路径规划分为基于环境信息已知的全局路径规划和基于环境信息未知或局部已知的局部路径规划。随着科技的快速发展以及机器人的大量…

cursor使用经验分享(java后端服务开发向)

前言 cursor是一款基于vscode,并集成AI能力的代码编辑器,其功能包括但不限于代码生成及补全、AI对话(能够直接将代码环境作为上下文)、即时应用建议等等,是一款面向未来的代码编辑器。 对于vscode,最先想…

【Java学习】异常

一、异常的处理过程 异常类的似复刻变量被throw时,会立即中止当前所在的这层方法,即当层方法里throw异常类似复刻变量之后的语句就不会执行了,如果throw异常语句在当层方法中被try{}包裹,则中止就先发生被包裹在了try{}层&#xf…

双足机器狗开发:Rider - Pi

双足机器狗开发:Rider - Pi https://github.com/YahboomTechnology/Rider-Pi-Robot 项目介绍 Rider - Pi是一款为开发者、教育工作者和机器人爱好者设计的桌面双轮腿式机器人,它基于树莓派CM4核心模块构建,具备多种先进功能和特点: 硬件特性 核心模块:采用树莓派CM4核…

vscode 查看3d

目录 1. vscode-3d-preview obj查看ok 2. vscode-obj-viewer 没找到这个插件: 3. 3D Viewer for Vscode 查看obj失败 1. vscode-3d-preview obj查看ok 可以查看obj 显示过程:开始是绿屏,过了1到2秒,后来就正常看了。 2. vsc…

Nginx 本地配置ssl证书

Nginx 本地配置ssl证书 主要为了本地使用https站点访问测试 本地linux 服务器环境为Centos7 本地安装mkcert证书工具 对于 Debian 或 Ubuntu 系统,你可以使用以下命令安装: sudo apt update sudo apt install mkcert # 验证是否安装成功 mkcert --vers…