前端Python应用指南(七)使用SQLAlchemy与Django ORM:数据库操作的Python实践

news2025/1/3 5:03:04

《写给前端的python应用指南》系列:

  • (一)快速构建 Web 服务器 - Flask vs Node.js 对比
  • (二)深入Flask:理解Flask的应用结构与模块化设计
  • (三)Django vs Flask:哪种框架适合构建你的下一个Web应用?
  • (四)Django实战:创建一个简单的博客系统
  • (五)用FastAPI快速构建高性能API
  • (六)构建RESTful API:使用Flask和Django实现用户认证与授权

在现代Web应用开发中,数据库操作是非常重要的一部分。无论是使用关系型数据库(如MySQL、PostgreSQL等)还是其他类型的数据库,如何高效、优雅地进行数据库操作一直是开发者们关注的重点。Python作为一门高效的编程语言,提供了多种数据库操作的方式,最常见的就是通过SQLAlchemyDjango ORM(对象关系映射)来与数据库进行交互。

在本篇博文中,我们将深入探讨SQLAlchemyDjango ORM的使用,了解它们的基本原理和使用方法,比较这两者的优缺点,帮助你选择最适合你的Web应用开发框架。

一、SQLAlchemy概述

SQLAlchemy是一个非常强大的Python数据库工具库,广泛用于数据库操作。它支持多种数据库类型,并且能够实现SQL的原生操作以及面向对象的数据库映射。SQLAlchemy提供了两种主要的操作方式:一种是核心模式(Core),另一种是ORM模式(Object Relational Mapper)。ORM模式允许你以面向对象的方式与数据库进行交互,简化了数据库操作。

1.1 安装SQLAlchemy

首先,我们需要安装SQLAlchemy库。如果你还没有安装SQLAlchemy,可以通过以下命令安装:

pip install sqlalchemy

如果你使用的是关系型数据库(如MySQL或PostgreSQL),你可能还需要安装数据库的驱动,例如:

  • 对于MySQL:pip install pymysql
  • 对于PostgreSQL:pip install psycopg2
1.2 SQLAlchemy的基础使用

以下是使用SQLAlchemy创建数据库表并执行一些基本操作的代码示例:

  1. 创建SQLAlchemy模型:
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

# 创建一个基础类
Base = declarative_base()

# 定义一个用户模型
class User(Base):
    __tablename__ = 'users'

    id = Column(Integer, primary_key=True)
    username = Column(String(50), unique=True)
    email = Column(String(100))

    def __repr__(self):
        return f"<User(id={self.id}, username={self.username}, email={self.email})>"

# 创建数据库连接(这里使用SQLite)
engine = create_engine('sqlite:///users.db')

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

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

# 添加数据
new_user = User(username='john_doe', email='john@example.com')
session.add(new_user)
session.commit()

# 查询数据
users = session.query(User).all()
print(users)
1.3 SQLAlchemy与数据库交互

SQLAlchemy的优势在于它提供了一个非常灵活和强大的查询构建系统,支持复杂的SQL查询。你可以通过ORM模型直接进行数据操作,或者通过SQLAlchemy的核心接口编写原生SQL查询。

  • 插入数据:
new_user = User(username='alice', email='alice@example.com')
session.add(new_user)
session.commit()
  • 查询数据:
user = session.query(User).filter_by(username='alice').first()
print(user)
  • 更新数据:
user = session.query(User).filter_by(username='alice').first()
user.email = 'new_email@example.com'
session.commit()
  • 删除数据:
user = session.query(User).filter_by(username='alice').first()
session.delete(user)
session.commit()

二、Django ORM概述

Django是一个全栈Web框架,内置了强大的ORM(对象关系映射)功能,使得开发者可以通过Python对象与数据库进行交互。与SQLAlchemy相比,Django ORM更注重于简化开发流程,默认提供了很多高层次的功能,特别适合构建复杂的Web应用。

2.1 安装Django

如果你还没有安装Django,可以通过以下命令进行安装:

pip install django
2.2 创建Django项目和应用

假设你已经有了一个Django项目,我们将在该项目中创建一个简单的用户模型,并使用Django ORM进行数据库操作。

  1. 创建Django项目和应用:
django-admin startproject myproject
cd myproject
python manage.py startapp accounts
  1. 配置数据库:

myproject/settings.py中配置数据库连接。默认情况下,Django使用SQLite作为数据库,你可以根据需要更改为MySQL、PostgreSQL等。

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',  # 使用SQLite数据库
        'NAME': BASE_DIR / 'db.sqlite3',  # 数据库文件
    }
}
2.3 定义模型

在Django中,我们通过定义models.py中的模型类来创建数据库表。每个模型类都继承自django.db.models.Model

  1. 创建用户模型:

accounts/models.py中创建一个用户模型:

from django.db import models

class User(models.Model):
    username = models.CharField(max_length=50, unique=True)
    email = models.EmailField(max_length=100)

    def __str__(self):
        return f"{self.username} <{self.email}>"
  1. 运行数据库迁移:

Django ORM通过迁移机制来创建和更新数据库。你需要先生成迁移文件,然后应用迁移文件来创建数据库表。

python manage.py makemigrations accounts
python manage.py migrate
2.4 数据库操作
  1. 插入数据:
from accounts.models import User

# 创建并保存用户
user = User(username='john_doe', email='john@example.com')
user.save()
  1. 查询数据:
# 查询所有用户
users = User.objects.all()
print(users)

# 查询特定用户
user = User.objects.get(username='john_doe')
print(user)
  1. 更新数据:
user = User.objects.get(username='john_doe')
user.email = 'new_email@example.com'
user.save()
  1. 删除数据:
user = User.objects.get(username='john_doe')
user.delete()

三、SQLAlchemy vs Django ORM

SQLAlchemy和Django ORM都提供了强大的数据库操作功能,但它们在设计理念、功能以及使用方式上有所不同。

3.1 灵活性 vs 约定优于配置
  • SQLAlchemy:提供了非常灵活的数据库操作方式,适合有复杂数据库操作需求的项目。SQLAlchemy允许你更直接地控制数据库表、查询以及事务等操作,适合需要复杂查询和自定义的场景。
  • Django ORM:遵循约定优于配置的原则,自动生成许多配置,简化了数据库操作。它更适合快速开发Web应用,特别是当你不需要过多的自定义和复杂查询时,Django ORM会自动为你处理很多数据库相关的工作。
3.2 学习曲线
  • SQLAlchemy:由于SQLAlchemy的灵活性,它的学习曲线相对较陡,尤其是在需要使用SQLAlchemy Core进行原生SQL查询时。你需要了解数据库的细节,特别是在复杂查询和数据关系建模时。
  • Django ORM:Django ORM的学习曲线较为平缓。由于Django遵循了严格的MVC(模型-视图-控制器)架构,并且大量约定了默认行为,使得开发者可以快速上手并专注于业务逻辑而不是数据库细节。
3.3 功能比较
特性SQLAlchemyDjango ORM
数据库支持支持多种数据库(MySQL, PostgreSQL, SQLite等)支持多种数据库(MySQL, PostgreSQL, SQLite等)
复杂查询支持提供强大的查询构建工具,可执行复杂SQL查询提供基本的查询功能,支持联表查询、聚合查询等
数据库迁移使用Alembic进行数据库迁移内置数据库迁移功能,自动生成迁移文件
灵活性高,适用于高度自定义的数据库操作较低,适用于常见的Web应用开发场景
学习曲线陡峭,适合中高级开发者平缓,适合快速开发和初学者

四、选择SQLAlchemy还是Django ORM?

  • 如果你正在开发一个需要高度自定义数据库操作、复杂查询或多数据库支持的项目,或者你已经习惯了SQL的工作方式,SQLAlchemy将是一个更合适的选择。
  • 如果你正在使用Django框架,且

项目的数据库操作需求相对简单,Django ORM会大大简化你的工作,让你能快速开发和部署应用。

五、总结

SQLAlchemy和Django ORM是Python开发中非常常用的数据库操作工具,它们各自有着不同的优势和适用场景。SQLAlchemy灵活且功能强大,适合高度自定义的项目;而Django ORM则简化了数据库操作,使得开发者能够更专注于业务逻辑。

希望通过本文的讲解,你能够了解SQLAlchemy和Django ORM的基本使用,并能够根据你的项目需求选择合适的工具进行数据库操作。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

嵌入式开发中的机器人表情绘制

机器人的表情有两种&#xff0c;一种是贴图&#xff0c;一钟是调用图形API自绘。 贴图效果相对比较好&#xff0c;在存储空间大的情况下是可以采用的。 自绘比较麻烦&#xff0c;但在资源和空缺少的情况下&#xff0c;也是很有用的。而且自绘很容易通过调整参数加入随机效果&…

opencv实现KNN算法识别图片数字

KNN算法实现识别图片数字 目录 KNN算法实现识别图片数字图片基本情况图片数据 图片数字识别图片数据处理及预测其它数字图片正确率预测 图片基本情况 图片 数据 图片像素是2000x1000,即高&#xff08;行&#xff09;1000&#xff0c;宽&#xff08;列&#xff09;2000&#xf…

美畅物联丨视频上云网关获取视频流地址供第三方调用的方法

在视频监控与流媒体传输领域&#xff0c;视频流地址的获取与调用是极为关键的环节。视频上云网关作为一款高效且稳定的视频传输设备&#xff0c;为获取视频流地址提供了便捷途径&#xff0c;从而使外部系统或平台能够方便地进行调用。今天我们就来讨论一下如何在视频上云网关上…

MySQL数据库——索引结构之B+树

本文先介绍数据结构中树的演化过程&#xff0c;之后介绍为什么MySQL数据库选择了B树作为索引结构。 文章目录 树的演化为什么其他树结构不行&#xff1f;为什么不使用二叉查找树&#xff08;BST&#xff09;&#xff1f;为什么不使用平衡二叉树&#xff08;AVL树&#xff09;&a…

一起学Git【第六节:查看版本差异】

git diff是 Git 版本控制系统中用于展示差异的强大工具。他可以用于查看文件在工作区、暂存区和版本库之间的差异、任意两个指定版本之间的差异和两个分支之间的差异等,接下来进行详细的介绍。 1.显示工作区与暂存区之间的差异 # 显示工作区和暂存区之间的差异,后面不加参数…

Fetch处理大模型流式数据请求与解析

为什么有的大模型可以一次返回多个 data&#xff1f; Server-Sent Events (SSE)&#xff1a;允许服务器连续发送多个 data: 行&#xff0c;每个代表一个独立的数据块。 流式响应&#xff1a;大模型服务通常以流式响应方式返回数据&#xff0c;提高响应速度。 批量处理&#x…

期权懂|个股期权的流动性如何?

锦鲤三三每日分享期权知识&#xff0c;帮助期权新手及时有效地掌握即市趋势与新资讯&#xff01; 个股期权的流动性如何&#xff1f; 个股期权作为场外交易工具&#xff0c;具有较高的灵活性。场外交易意味着交易双方可以直接协商交易条款&#xff0c;这有助于满足不同投资者的…

国产低代码框架zdppy开发笔记002 标准的接口响应

前言 通过前面的学习, 我们已经知道了zdppy_api和zdppy_req的基本用法, 接下来我们会在学习中多次用到这两个框架. 我们已经知道了该如何响应一个字符串,但是我们该如何响应json数据呢? 在zdppy_api中,我们定义了一组规范的API响应, 我们慢慢来看看. 规范的响应 首先来看…

Linux | 零基础Ubuntu解压RaR等压缩包文件

目录 介绍 案例分析 安装工具 解压实践 介绍 RAR是一种专利文件格式&#xff0c;用于数据压缩与归档打包&#xff0c;开发者为尤金罗谢尔&#xff08;俄语&#xff1a;Евгений Лазаревич Рошал&#xff0c;拉丁转写&#xff1a;Yevgeny Lazarevich R…

Python基于卷积神经网络的车牌识别系统开发与实现

1. 简介 车牌识别是人工智能在交通领域的重要应用&#xff0c;广泛用于高速违章检测、停车场管理和智能交通系统等场景。本系统通过基于卷积神经网络&#xff08;CNN&#xff09;的深度学习算法&#xff0c;结合 Python 和 MySQL 实现车牌的快速识别与管理。 系统特点&#x…

stm32内部flash在线读写操作

stm32内部flash在线读写操作 &#x1f4cd;相关开源库文章介绍《STM32 利用FlashDB库实现在线扇区数据管理不丢失》 ✨不同系列&#xff0c;内部flash编程有所区别。例如stm32f1是按照页擦除&#xff0c;半字&#xff08;16bit&#xff09;或全字(32bit)数据写入&#xff1b;st…

IDEA | SpringBoot 项目中使用 Apifox 上传接口

目录 1 安装 Apifox Helper 插件2 获取 Apifox 的 API 访问令牌3 IDEA 中设置 API 访问令牌4 IDEA 中上传接口5 常见问题5.1 如何自动设置目录名5.2 如何自动设置接口名5.3 如何更改上传位置 Apifox 官方指南&#xff1a; https://apifox.com/help/applications-and-p…

Leetcode 10-正则表达式匹配/ 剑指 Offer 19. 正则表达式匹配

给你一个字符串 s 和一个字符规律 p&#xff0c;请你来实现一个支持 ‘.’ 和 ‘*’ 的正则表达式匹配。 ‘.’ 匹配任意单个字符 ‘*’ 匹配零个或多个前面的那一个元素 所谓匹配&#xff0c;是要涵盖 整个 字符串 s 的&#xff0c;而不是部分字符串。 题解 字符串匹配多…

学习vue3的笔记

一、vue和react的对比 1、基础介绍 vue&#xff1a;https://cn.vuejs.org/ vue3是2020年创建的 react&#xff1a;https://react.dev/ react是一个2013年开源的JavaScript库&#xff0c;严格意义上来说不是一个框架 2、diff算法 两个框架采用的都是同级对比策略 两节点对…

基于STM32的智能家居环境监控系统设计

目录 引言系统设计 硬件设计软件设计系统功能模块 环境监控模块控制模块显示模块系统实现 硬件实现软件实现系统调试与优化结论与展望 1. 引言 随着智能家居技术的发展&#xff0c;环境监控系统已经成为家居管理的重要组成部分。智能家居环境监控系统通过实时监测室内温度、湿…

【MySQL】搞懂mvcc、read view:MySQL事务原理深度剖析

前言&#xff1a;本节内容是事务里面最难的一部分&#xff0c; 就是理解mvcc快照读和read view。这两个部分需要了解隔离性里面的四种隔离级别。 博主之前讲过&#xff0c;但是担心友友们不了解&#xff0c; 所以这里开头进行了复习。 下面开始我们的学习吧&#xff01; ps&…

jmeter设置tps、响应时间监测时间间隔

jmeter设置tps、响应时间监测时间间隔 思路&#xff1a; 1、设置tps和响应时间插件的采集时间间隔&#xff0c;然后运行jmeter脚本&#xff1b; 2、先按默认配置跑出jtl文件保存下来&#xff0c;再添加tps和响应时间插件&#xff0c;设置采集时间间隔后&#xff0c;导入jtl文件…

Qt 12.30 day5

day5_testppp.proQT core gui texttospeech widget.h#ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTimerEvent>//定时器事件类 #include <QTimer>//时间事件类 #include <QTime>//时间类 #include <QTextToSpeech>//…

玩转OCR | 腾讯云智能结构化OCR初体验

随着数字化进程的加速&#xff0c;光学字符识别&#xff08;OCR&#xff09;技术已逐渐成为提高企业生产力、优化工作流的重要工具。腾讯云智能结构化OCR凭借其领先的技术、广泛的应用场景和灵活的定制化能力&#xff0c;正在帮助各行业客户更高效地进行文档处理与数据提取。本…

Spring Boot教程之三十九: 使用 Maven 将 Spring Boot 应用程序 Docker 化

如何使用 Maven 将 Spring Boot 应用程序 Docker 化&#xff1f; Docker是一个开源容器化工具&#xff0c;用于在隔离环境中构建、运行和管理应用程序。它方便开发人员捆绑其软件、库和配置文件。Docker 有助于将一个容器与另一个容器隔离。在本文中&#xff0c;为了将Spring B…