python flask配置数据库并进行orm操作 flask_sqlalchemy

  • 🌈所属专栏:【Flask】
  • 作者主页:  Mr.Zwq
  • ✔️个人简介:一个正在努力学技术的Python领域创作者,擅长爬虫,逆向,全栈方向,专注基础和实战分享,欢迎咨询!

您的点赞、关注、收藏、评论,是对我最大的激励和支持!!!🤩🥰😍

目录

简介

代码实现

exts.py文件

 models.py文件

config.py配置文件

main.py文件 

查询操作

页面输出

在数据库查看

插入操作

页面输出

在数据库查看

总结


简介

        Flask-SQLAlchemy是Flask框架中的一个扩展,它简化了在Flask应用中使用SQLAlchemy的操作。SQLAlchemy是一个强大的关系型数据库框架,它支持多种数据库后台,并提供了高层的对象关系映射(ORM)和底层的原生数据库操作。

以下是Flask-SQLAlchemy的简介,以分点表示和归纳的形式呈现:

  1. 基本概念
    • ORM(Object-Relational Mapping):对象关系映射,它将用户定义的Python类与数据库表相关联,并将这些类(对象)的实例与其对应表中的行相关联。
    • Flask-SQLAlchemy:作为Flask的扩展,它封装了SQLAlchemy的功能,使其更易于在Flask应用中使用。
  2. 优点
    • 面向对象编程:开发者可以通过Python对象来操作数据库,无需直接编写SQL语句。
    • 开发效率:通过ORM,开发者可以专注于业务逻辑的实现,而无需过多关注数据库操作的细节,从而提高开发效率。
    • 解耦与可移植性:实现了数据模型与数据库的解耦,使得更换数据库变得更加简单,无需修改业务代码。
  3. 安装与配置
    • 安装:通过pip命令安装Flask-SQLAlchemy和相应的数据库驱动(如pymysql用于MySQL)。
    • 配置:在Flask应用中配置数据库连接字符串(如SQLALCHEMY_DATABASE_URI),以及其他相关设置(如是否跟踪修改、是否输出SQL语句等)。
  4. 基本使用
    • 构建模型类:通过继承Flask-SQLAlchemy提供的基类(如db.Model),定义与数据库表对应的Python类。
    • 数据操作:包括增加数据、查询数据、修改数据和删除数据等,都可以通过模型类的方法来实现。
  5. 高级机制
    • 刷新数据:在某些情况下,可能需要手动刷新模型对象的状态,以确保其与数据库中的数据保持一致。
    • 多表查询:Flask-SQLAlchemy支持使用关系操作(如join)进行多表查询。
  6. 性能与可移植性
    • 性能:虽然ORM在一定程度上会带来性能损失(如对象与SQL之间的转换),但在大多数情况下,这种损失是可以接受的,且ORM对生产率的提升远远超过了这一丁点儿的性能降低。
    • 可移植性:SQLAlchemy支持多种数据库引擎,包括流行的MySQL、Postgres和SQLite等,因此使用Flask-SQLAlchemy的应用可以轻松地切换到不同的数据库。

        通过以上简介,可以看出Flask-SQLAlchemy是一个功能强大且易于使用的Flask扩展,它使得在Flask应用中进行数据库操作变得更加简单和高效。


代码实现

exts.py文件

# 扩展放在独立文件供其它地方进行引用,可有效防止循环导包问题
from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

 models.py文件

from exts import db
from datetime import datetime

# 测试用户表
class User(db.Model):
    __tablename__ = 'user'
    id = db.Column(db.Integer, primary_key=True)
    account = db.Column(db.String(50), unique=True, nullable=False)
    password = db.Column(db.String(32), nullable=False)
    name = db.Column(db.String(50), nullable=False)
    avatar = db.Column(db.String(100),default='1.jpg')
    desc = db.Column(db.String(256))
    role = db.Column(db.String(50))
    create_time = db.Column(db.DateTime, default=datetime.now)

config.py配置文件

class Config():
    # 数据库配置信息
    host = '127.0.0.1'  # 主机
    port = 3306         # 端口
    user = 'root'       # MySQL账户
    pwd = '123456'      # MySQL密码
    database = 'test_2' # 使用的数据库名称
    # SQLALCHEMY_DATABASE_URI = 'sqlite:///XXX.db'  # sqlite数据库的配置(数据库名称:XXX.db)
    SQLALCHEMY_DATABASE_URI = f"mysql+pymysql://{user}:{pwd}@{host}:{port}/{database}?charset=utf8mb4"   # MySQL数据库
    SQLALCHEMY_ECHO = False  # 查询时是否显示原始SQL语句,为False不显示
    SQLALCHEMY_TRACK_MODIFICATIONS = False  # 跟踪数据库的修改,会增加性能消耗,不建议开启

main.py文件 

from flask import Flask
from config import Config
from exts import db
from models import User

app = Flask(__name__)

# 读取参数配置
app.config.from_object(Config)
# db对象
db.init_app(app)


@app.route('/')
def index():
    # 进行查询操作
    users=User.query.all()
    print(users)
    users=[{'id':i.id,'account':i.account,'name':i.name} for i in users]
    return users

@app.route('/add')
def add():
    # 模拟插入数据
    users=User(account='test@qq.com',name='test',password='test')
    db.session.add(users)
    db.session.commit()
    return 'add'


if __name__ == '__main__':
    app.run(debug=True)

查询操作

页面输出

 

在数据库查看​


插入操作

页面输出

在数据库查看


总结

感谢观看,原创不易,如果觉得有帮助,请给文章点个赞吧,让更多的人看到。🌹🌹🌹

👍🏻也欢迎你,关注我。👍🏻

如有疑问,可在评论区留言哦~

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

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

相关文章

LeetCode | 28.找出字符串中第一个匹配项的下标 KMP

这是字符串匹配问题,朴素做法是两重遍历,依次从主串的i位置开始查看是否和模式串匹配,若不匹配就换下一个位置进行判断,直到找到或者遍历完,时间复杂度 O ( m n ) O(m \times n) O(mn) 还可以对主串进行处理&#xff…

第一个 JavaFX 应用程序

在本教程中,我将向你展示如何创建您的第一个 JavaFX 应用程序。因此,本教程既可以向你介绍核心 JavaFX 概念,也可以为你提供一些 JavaFX 代码,你可以将其用作你自己的实验的模板。 JavaFX 应用程序类 JavaFX 应用程序需要一个主…

【论文复现|智能算法改进】基于多策略融合灰狼算法的移动机器人路径规划

目录 1.算法原理2.改进点3.结果展示4.参考文献5.代码获取 1.算法原理 【智能算法】灰狼算法(GWO)原理及实现 2.改进点 混沌反向学习策略 融合Logistic混沌映射和Tent混沌映射生成Logistic-Tent复合混沌映射: Z i 1 { ( r Z i ( 1 − Z i ) ( 4 −…

下载mysql-8.0.33-1.el7.x86_64.rpm-bundle.tar操作教程

1、下载地址:MySQL :: Download MySQL Community Server (Archived Versions) 2、截图如下

中华老字号李良济,展现百年匠心之魅力,释放千年中医药文化自信

6月14-16日,“潮品老字号 国货LU锋芒”江苏老字号博览会在南京隆重启幕,中华老字号李良济凭借过硬的品牌实力和优质的口碑再次受邀参加,并在展会上绽放百年匠心魅力,彰显千年中医药文化自信! 百年匠心 以实力铸就荣耀…

Autosar诊断-FIM模块功能介绍

文章目录 前言一、FIM模块概述二、FID概念介绍Event ID和DTC之间的关系Event ID与FID之间的关系FIM数据结构三、FiM模块与SW-C模块交互关系四、FIM模块函数调用关系FiM功能模块作用过程前言 Autosar诊断的主体为UDS(Unified Diagnostic Services)协议,即统一的诊断服务,是…

linux如何部署前端项目和安装nginx

要在Linux上部署前端项目并安装Nginx,你可以按照以下步骤操作: 安装Nginx: sudo apt update sudo apt install nginx 启动Nginx服务: sudo systemctl start nginx 确保Nginx服务开机自启: sudo systemctl enable nginx 部署前端项目,假设前…

PromptMRG: Diagnosis-Driven Prompts for Medical Report Generation

文章汇总 存在的问题 罕见疾病在训练数据中的代表性不足,使其诊断性能不可靠。 解决办法 1:利用预训练的CLIP模型从数据库中检索相似的报告来辅助查询图像的诊断。 2:设计SDL模块根据不同疾病的学习状态自适应调整优化目标。 流程解读 文…

MPLS VPN一

R1为客户,现在进行一些基本配置,来确保可以通路由 先启动OSPF跑通 在R3上 等一会 现在启动MPLS 对R3 对R4 然后在R2上 再把接口划到空间里面 原来的IP在公网里面,被清除了 然后再配置接口 查看 对R1(相当于客户) …

2024年最易被破解的密码TOP50,你中招了吗?

今天,我们要聊聊一个每个人都会用到,但可能并不那么重视的话题——密码安全。密码,这个看似简单的字符组合,其实与我们的信息安全、财产安全密切相关。想象一下,如果你的手机、邮箱、银行账户等都被一个简单的密码保护…

vulnhub靶机hacksudoLPE中Challenge-1

下载地址:https://download.vulnhub.com/hacksudo/hacksudoLPE.zip 主机发现 目标146 端口扫描 服务扫描 漏洞扫描 上面那整出来几个洞,可以试试 easy? 估计就是看源码 看来是的 登入咯 这里进不去就是ssh咯 这个看着有点像提权的操作 一…

Java与数据库连接技术JDBC关键核心之PreparedStatement以及SQL注入演示解决和原理

PreparedStatement SQL注入 执行预编译的SQL对象 这样也能登录成功 模拟 SQL注入是这个原因 现在基本上不存在SQL注入的问题 解决 SQL注入就是传一些语句导致原来的SQL语句改变了 修改代码 通过设置参数的方式 就能防止SQL注入 实际上我们进行了一个转化 将字符和关键字进…

【健身经验】3 拜拜肉

1 女性手臂粗细与紧实程度,除了取决于运动和生活习惯,很大程度上取决于遗传因素 2 2 如果体脂已经很正常了,整体看起来匀称不胖,偏偏这两块肌肉附近的脂肪“顽固不化”的话,可以试试以下两个简单方法 对于体脂率正常…

Python第二语言(十一、Python面向对象(下))

目录 1. 封装 1.1 私有成员:__成员、__成员方法 2. 继承:单继承、多继承 2.1 继承的基础语法 2.2 复写 & 子类使用父类成员 3. 变量的类型注解:给变量标识变量类型 3.1 为什么需要类型注解 3.2 类型注解 3.3 类型注解的语法 3.…

基于51单片机万年历设计—显示温度农历

基于51单片机万年历设计 (仿真+程序+原理图+设计报告) 功能介绍 具体功能: 本系统采用单片机DS1302时钟芯片LCD1602液晶18b20温度传感器按键蜂鸣器设计而成。 1.可以显示年月日、时分秒、星期、温度值。…

CodeQL从入门到入土

为什么在现在写这文章 CodeQL传闻找到了Log4j的漏洞,这段时间上边要求,把公司系统内部常见的问题用CodeQL写检测脚本,用于系统长期检测。主要是记录这段时间的学习,以及自己总结的常用写法。 一个需求,不同人写出来的…

【数学】什么是傅里叶级数与傅里叶变换?

傅里叶级数与傅里叶变换 背景 傅里叶级数和傅里叶变换是数学和工程领域中的重要工具,特别是在信号处理、图像处理和物理学中。傅里叶级数用于将周期函数表示为正弦和余弦函数的和,而傅里叶变换用于将任意函数表示为频率的函数。 公式 傅里叶级数&…

java程序什么时候需要在运行的时候动态修改字节码对象

一、java程序什么时候需要在运行的时候动态修改字节码对象 我认为有两种场景,一种是无法修改源代码的时候;另外一种是功能增强的时候。 1、无法修改源代码 举个例子,java程序依赖的第三方的jar包中发现了bug,但是官方还没有修复…

0-1 构建用户画像数仓

目录 前言 一、用户画像概述 1.1 用户画像 1.2 用户标签 1.3 用户群组 二、建设标签和标签体系 2.1 标签体系 2.1.1 统计类标签 2.1.2 规则类标签 2.1.3 机器学习挖掘类标签 2.2 标签建设流程 2.2.1 需求收集与分析 2.2.2 产出标签需求文档 2.2.3 标签的开发 H…