一文带大家快速上手SQLAlchemy 对数据的增删改查操作

news2024/10/8 12:36:35

SQLAlchemy  

SQLAlchemy“采用简单的Python语言,为高效和高性能的数据库访问设计,实现了完整的企业级持久模型”。SQLAlchemy的理念是,SQL数据库的量级和性能重要于对象集合。我们可以使用Flask和SQLAlchemy的数据库访问层(DAL)轻松实现增删改查(CRUD)功能的封装!我们可以按照以下步骤进行。

这里假设你已经有一个Flask应用和一个SQLAlchemy数据库实例。

首先,我们需要定义数据库模型(Model)

然后创建一个数据访问层(Repository)来封装CRUD操作。

定义数据库模型

models.py文件中定义你的数据库模型。

from flask_sqlalchemy import SQLAlchemy  
  
db = SQLAlchemy()  
  
class User(db.Model):  
    id = db.Column(db.Integer, primary_key=True)  
    username = db.Column(db.String(80), unique=True, nullable=False)  
    email = db.Column(db.String(120), unique=True, nullable=False)  
  
    def __repr__(self):  
        return f'<User {self.username}>'

在Repository中实现增删改查封装

在repositories.py文件中创建数据访问层,封装CRUD操作。

class UserRepository:  
    def __init__(self):  
        self.db = current_app.extensions['sqlalchemy'].db  
  
    def add_user(self, username, email):  
        new_user = User(username=username, email=email)  
        self.db.session.add(new_user)  
        self.db.session.commit()  
  
    def get_user_by_id(self, user_id):  
        return User.query.get(user_id)  
  
    def get_user_by_username(self, username):  
        return User.query.filter_by(username=username).first()  
  
    def update_user(self, user_id, username=None, email=None):  
        user = self.get_user_by_id(user_id)  
        if user:  
            if username:  
                user.username = username  
            if email:  
                user.email = email  
            self.db.session.commit()  
  
    def delete_user(self, user_id):  
        user = self.get_user_by_id(user_id)  
        if user:  
            self.db.session.delete(user)  
            self.db.session.commit()  

SQLAlchemy 在flask中的完整应用

from flask import Flask  
from flask_sqlalchemy import SQLAlchemy  
from .models import db  # 假设你的models.py在同一目录下  
  
app = Flask(__name__)  
app.config['SQLALCHEMY_DATABASE_URI'] ='mysql+pymysql://user:4ag;password@ip:port/your_db'


app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False  
db.init_app(app)  
  
# 确保在应用上下文中使用数据库,如果不需要创建表,这段代码可以忽略  
with app.app_context():  
    db.create_all()  # 创建所有表  
  
# 你可以在这里导入并使用UserRepository  
from .repositories import UserRepository  
  
# 示例:在视图中使用UserRepository  
@app.route('/add_user', methods=['POST'])  
def add_user():  
    # 假设你有一个方法来解析POST请求中的username和email  
    username = request.form['username']  
    email = request.form['email']  
    repo = UserRepository()  
    repo.add_user(username, email)  
    return 'User added successfully!', 201  

我的每一篇文章都希望帮助读者解决实际工作中遇到的问题!如果文章帮到了您,劳烦点赞、收藏、转发!您的鼓励是我不断更新文章最大的动力! 


  

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

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

相关文章

别人苦画流程图一小时,我却瞬间搞定12 种图表!

在AI写作中&#xff0c;如何才能生成各种图表呢&#xff1f;例如流程图、序列图、甘特图等&#xff0c;今天就来教你如何生成。 本文阅读难度&#xff1a;★☆☆☆☆ 在商业、学术场景中&#xff0c;经常需要画流程图&#xff0c;手工画的话至少得1个小时才能完画&#xff0c…

宠物咖啡馆数字化转型:SpringBoot框架的实践

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理基于Spring Boot的宠物咖啡馆平台的设计与…

gstreamer 内存 alloctor 介绍

文章目录 前言一、gstreamer 默认的内存 alloctor1. gstreamer 中默认的内存 allocator 为 GST_ALLOCATOR_SYSMEM (即SystemMemory)2. GST_ALLOCATOR_SYSMEM 申请内存实例二、gstreamer 目前支持的几种内存 alloctor1.GstDmaBufAllocator1.1 GstDmaBufAllocator 介绍1.2 GstDma…

马丁代尔药物大典数据库

马丁代尔药物大典是一本由Pharmaceutical Press出版的参考书&#xff0c;拥有全球使用的近 6000 种药物和药品&#xff0c;包括超过 125,000 种专有制剂的详细信息。其中还包括近 700 篇疾病治疗评论。 它于 1883 年首次出版&#xff0c;马丁代尔包含全球临床用药信息&#xff…

pytest的基础入门

pytest判断用例的成功或者失败 pytest识别用例失败时会报AssertionError或者xxxError错误&#xff0c;当捕获异常时pytest无法识别到失败的用例 pytest的fixture夹具 pytest的参数化 #coding:utf-8 import pytestfrom PythonProject.pytest_test.funcs.guess_point import ge…

android 绘制流程

网上看了一些绘制相关的框架图&#xff0c;感觉有些不对&#xff0c;先记录下 主要是 surface 和framebuffer的关系&#xff0c;surface是用来管理数据内容并最终通过layer输出framebuffer的&#xff0c;因此应该是上下两层的管理&#xff0c;而不是平行的 二hwc合并内容&…

STM32 HAL库UART查询方式实例

本文中介绍USART编程涵盖了三种主要方法&#xff0c;详细介绍STM32F407微控制器结合HAL库&#xff0c;通过UART的查询方式来实现一个实用的密码验证程序。提示用户键入一个字符作为密码。只有当用户精准地输入字符6时&#xff0c;系统才会反馈“密码正确”的确认信息。反之&…

vscode 中显示 pnpm : 无法加载文件 C:\Users\AppData\Roaming\npm\pnpm.ps1,因为在此系统上禁止运行脚本

vscode中运行pnpm报错 pnpm : 无法加载文件 C:\Users\AppData\Roaming\npm\pnpm.ps1&#xff0c;因为在此系统上禁止运行脚本 解决办法如下 1、用 get-ExecutionPolicy 命令在vscode终端查询状态 如果返回的是 Restricted &#xff0c;则说明是禁止的 2、用 set-ExecutionPolic…

从零开始构建:Python自定义脚本自动化你的日常任务

从零开始构建&#xff1a;Python自定义脚本自动化你的日常任务 Python 作为一种简洁且功能强大的编程语言&#xff0c;被广泛应用于各种自动化任务中。通过编写 Python 脚本&#xff0c;你可以轻松地将日常重复性工作自动化&#xff0c;例如文件操作、数据处理、网络爬虫、系统…

Mac 电脑设置键盘 Command键

Mac 电脑设置键盘 Command键 如果 mac 电脑连接的第三方键盘&#xff0c;有些键盘没有 command 按键&#xff0c;导致有些功能没有办法使用&#xff0c;比如你想复制粘贴发现也不可以。这个时候你需要设置一个按键为 command 按键。 比如上图中是把 Alt 键设置为 Command 键。 …

DHCP安装

步骤 1&#xff1a;安装DHCP服务器 在系统上安装DHCP服务。以下是安装命令&#xff1a; # 安装DHCP软件包 yum install dhcp步骤 2&#xff1a;配置DHCP服务器 安装完成后&#xff0c;需要配置DHCP服务器来绑定MAC地址和IP地址。 # 备份原始的DHCP配置文件 cp /etc/dhcp/dh…

华为 HCIP-Datacom H12-821 题库 (33)

&#x1f423;博客最下方微信公众号回复题库,领取题库和教学资源 &#x1f424;诚挚欢迎IT交流有兴趣的公众号回复交流群 &#x1f998;公众号会持续更新网络小知识&#x1f63c; 1.VLAN Pool 只要通过一个 SSID 就能够同时支持多个业务 VLAN&#xff0c;从而缩小广播域&#…

[含文档+PPT+源码等]精品大数据项目-基于python爬虫实现的大数据岗位的挖掘与分析

大数据项目——基于Python爬虫实现的大数据岗位的挖掘与分析&#xff0c;其背景主要源于以下几个方面&#xff1a; 一、大数据时代的来临 随着互联网、物联网、云计算等技术的快速发展&#xff0c;数据呈现出爆炸式增长。根据国际数据公司&#xff08;IDC&#xff09;的预测&…

送给fans的一封感谢信

引言 首先&#xff0c;十分感谢&#xff0c;这几个月里粉丝的点赞和关注。我同时手里也有很多资料。也像跟大家分享&#xff0c;促进大家一起进步。可以加我企鹅2101750384。或者绿泡泡qier3451841065 &#xff08;加好友验证的时候&#xff0c;记得填“胡萝卜不甜”&#xff0…

241006-Gradio中Chatbot通过CSS自适应调整高度

A. 最终效果 B. 参考代码 import gradio as grCSS """ .contain { display: flex; flex-direction: column; } .gradio-container { height: 100vh !important; } #component-0 { height: 100%; } #chatbot { flex-grow: 1; overflow: auto;} #tab_item_4 { …

LeetCode-871 最低加油次数

重启力扣每日一题系列&#xff01; 因为过去两个月里掉粉掉的好严重&#xff0c;我想大抵是因为更新的频率不如上半年了&#xff0c;如果我重启了每日一题系列那岂不是至少是每日一更☝&#x1f913;&#xff1f; 也不是每天都更&#xff0c;我有两不更&#xff0c;特难的就不…

LIN总线学习大全(基于CANoe和CAPL)

&#x1f345; 我是蚂蚁小兵&#xff0c;专注于车载诊断领域&#xff0c;尤其擅长于对CANoe工具的使用&#x1f345; 寻找组织 &#xff0c;答疑解惑&#xff0c;摸鱼聊天&#xff0c;博客源码&#xff0c;点击加入&#x1f449;【相亲相爱一家人】&#x1f345; 玩转CANoe&…

Linux操作系统——概念扫盲I

目录 虚拟机概念刨析 在那之前&#xff0c;询问什么是虚拟化&#xff1f; 现在来看看什么是虚拟机 虚拟机有啥好的 小差&#xff1a;那JVM也叫Java Virtual Machine&#xff0c;有啥区别呢&#xff1f; Reference 虚拟机概念刨析 我们下面来简单聊聊虚拟机这个概念。对于…

一款开源Ai语音合成TTS工具:Fish Speech

在人工智能和语音技术日新月异的今天&#xff0c;Fish Speech项目以其卓越的性能和广泛的应用前景&#xff0c;成为了开源语音合成领域的一颗璀璨新星。 该项目由Fish Audio团队倾力打造&#xff0c;旨在为研究者、开发者和普通用户提供一个高质量、易用且功能强大的语音合成解…

Docker13-图形工具Portainer

零、文章目录 Docker13-图形工具Portainer 1、图形化管理工具 Docker 的图形化管理工具可以帮助用户更直观地管理 Docker 容器、镜像、网络和数据卷等。 选择哪个工具取决于您的具体需求&#xff0c;比如是否需要支持远程管理、是否需要集成 Kubernetes、是否偏好桌面应用或…