【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,面试宝典等分享。

所属的专栏:flask框架零基础,进阶应用实战教学
景天的主页:景天科技苑

文章目录

  • ORM
    • Flask-SQLAlchemy
    • 原生SQLAlchemy连接配置操作
    • 针对数据库的增删改查操作
      • 添加数据
      • 添加多条数据
      • 查询所有数据
      • 按条件查询
      • 更新一条数据
      • 更新多条数据
      • 删除一条数据
      • 删除多条数据
      • 执行原生sql语句
    • 总结

ORM

ORM 全拼Object-Relation Mapping,中文意为 对象-关系映射。主要实现模型对象到关系数据库数据的映射。

ORM提供了一种面向对象操作数据库的方式给开发者。不需要编写原生SQL语句也能操作数据库,实现了业务代码与底层数据的解耦。

优点:

  • 只需要面向对象编程, 不需要面向数据库编写SQL。
    • 对数据库的操作都转化成对类/对象的属性和方法的操作. 表字段—>对象属性, SQL关键字-> 操作方法
    • 不用编写各种数据库的原生sql语句,当然也可以编写原生SQL语句。
  • 实现了数据模型代码与数据库数据的解耦, 屏蔽了不同数据库操作上的差异。
    • 不再需要关注当前项目使用的是哪种数据库。
    • 通过简单的配置就可以轻松更换数据库, 而不需要修改业务代码.

缺点:

  • 相比较直接使用SQL语句操作数据库,ORM需要把操作转换成SQL语句,所以有性能损失.
  • 根据对象的操作转换成SQL语句,根据查询的结果转化成模型实例对象, 在映射过程中有性能损失.
  • 不同的ORM提供的操作不一样,增加了学习成本

flask与python原生操作数据库流程对比
在这里插入图片描述

Flask-SQLAlchemy

flask默认不提供数据库操作,也并没有提供ORM,所以一般开发的时候我们会采用flask-SQLAlchemy模块来实现ORM操作。

SQLAlchemy是一个python语言编写的高性能的关系型数据库ORM框架,它提供了高层的 ORM 和底层的原生数据库的操作。

我们使用sqlalchemy 不需要调用sqlalchemy 本身这个模块,而是采用flask-sqlalchemy ,这是一个简化了 SQLAlchemy 操作的flask扩展模块。(主要是简化了sqlalchemy初始化代码和分页操作等)

安装 flask-sqlalchemy

pip install flask-sqlalchemy

在这里插入图片描述

如果sqlalchemy连接的是 mysql /MariaDB数据库,需要安装 mysqldb 或pymysql驱动

pip install pymysql

原生SQLAlchemy连接配置操作

db.py,代码:

from sqlalchemy import create_engine   # 驱动引擎
from sqlalchemy.ext.declarative import declarative_base # 数据库基类
from sqlalchemy import Column, Integer, String, Boolean, Numeric, Text # 字段、整型
from sqlalchemy.orm import sessionmaker  # 连接会话#创建数据库连接引擎
engine = create_engine(# 连接数据库的URL,url里面是数据库类型+数据库驱动url="mysql+pymysql://root:Jin*******7!@10.10.0.52:3306/students?charset=utf8mb4",  # 如果底层驱动是pymysql# url="mysql://root:123@127.0.0.1:3306/students?charset=utf8mb4",    # 如果底层驱动是MysqlDBecho=True, # 当设置为True时会将orm语句转化为sql语句打印,一般debug的时候可用pool_size=8, # 连接池的大小,默认为5个,设置为0时表示连接无限制pool_recycle=60*30 # 设置时间以限制数据库多久没连接自动断开,单位是秒
)#创建会话连接
DbSession = sessionmaker(bind=engine)
session = DbSession()# 创建数据基类
Model = declarative_base()

在这里插入图片描述

manage.py,代码:

import db
#声明的数据库类要继承我们创建的数据库基类
class Student(db.Model):#声明表名__tablename__ = "flask_student"#设置表中的字段,字段类型,约束等id = db.Column(db.Integer, primary_key=True)name = db.Column(db.String(255))sex  = db.Column(db.Boolean)age  = db.Column(db.Integer)#如果表中有的字段是python中的关键字,则不能直接定义,需要用到别名转换class_name = db.Column("class", db.String(255),)description = db.Column(db.Text)is_delete = db.Column(db.Boolean, nullable=True, default=False)if __name__ == '__main__':# 如果没有提前声明模型中的数据表,则可以采用以下代码生成数据表,# 如果数据库中已经声明了有数据表,则不会继续生成db.Model.metadata.create_all(db.engine)

执行,可以看到执行的sql语句
在这里插入图片描述

查看数据库,有创建我们指定的表
在这里插入图片描述

看下表结构
在这里插入图片描述

针对数据库的增删改查操作

添加数据

# 添加一条数据
student = Student(name="zhangsan",class_name="301",sex=True,age=18,description="张三爱发明",is_delete = True
)
db.session.add(student)
db.session.commit()

在这里插入图片描述

数据库查看
在这里插入图片描述

添加多条数据

student_list = [Student(name="xiaohei", class_name="305", sex=False, age=18, description="美美的..",),Student(name="xiaobai", class_name="304", sex=True, age=18, description="美美的..",),Student(name="xiaohui", class_name="303", sex=False, age=18, description="美美的..",),
]db.session.add_all(student_list)
db.session.commit()

在这里插入图片描述

在数据库中查看
在这里插入图片描述

查询所有数据

data_list = db.session.query(Student).all()
print(data_list)
for data in data_list:print(data.name)

在这里插入图片描述

默认我们打印出来查询的是类对象,我们可以在模型类中通过__repr__方法,将类对象转化为我们自定义的格式化字符串

def __repr__(self):return f"<{self.name} {self.__class__.__name__}>"

在这里插入图片描述

在这里插入图片描述

根据ID查询一条数据,query里面的参数是我们创建的表类名,查询不到返回为None

ret = db.session.query(Student).get(1)
print(ret)
print(ret.name)
print(ret.class_name)

在这里插入图片描述

查询不存在的id,返回为None
在这里插入图片描述

所以,查询之前要做个判断
在这里插入图片描述

按条件查询

data_list = db.session.query(Student).filter(Student.sex==True, Student.class_name=='301').all()
print(data_list)
for data in data_list:print(data.sex, data.name)

在这里插入图片描述

更新一条数据

student = db.session.query(Student).get(35)
student.name = "小会"
db.session.commit()

在这里插入图片描述

查看数据库,可见id为3的记录名字已被修改
在这里插入图片描述

更新多条数据

db.session.query(Student).filter(Student.class_name=="305").update({Student.age:Student.age+1})
db.session.commit()

先看下更新之前,班级为305的学生的年龄都是18岁
在这里插入图片描述

执行之后
在这里插入图片描述

年龄被修改
在这里插入图片描述

删除一条数据

student = db.session.query(Student).get(3)
db.session.delete(student)
db.session.commit()

在这里插入图片描述

id为3的数据被删除
在这里插入图片描述

删除多条数据

db.session.query(Student).filter(Student.class_name == "304").delete()
db.session.commit()

删除之前,我们先添加些数据
在这里插入图片描述

执行删除
在这里插入图片描述

可见班级为304的数据已被删除
在这里插入图片描述

执行原生sql语句

# 原生SQL语句
# 读
cursor = db.session.execute('select * from flask_student;')
#一条
data = cursor.fetchone()
print(data)

此时,会报如下错误
在这里插入图片描述

出错原因:是因为因为安装的python包依赖sqlalchmy版本不一致造成的

我的代码原来是这样的db.session.execute(“select * from flask_student”)把他改成

db.session.execute(text(“select * from flask_student”))这样,然后记得导入from sqlalchemy.sql import text。就可以了。

最新用法

# 原生SQL语句
from sqlalchemy.sql import text
# 读
cursor = db.session.execute(text('select * from flask_student'))
#一条
data = cursor.fetchone()
print(data)

在这里插入图片描述

#获取多条

data_list = cursor.fetchall()
print(data_list)

在这里插入图片描述

写[添加、删除、修改]

sql ='insert into flask_student(name, class, age, sex, description,is_delete) values(:name, :class, :age, :sex, :description, :is_delete)'
cursor = db.session.execute(text(sql),params={"name": "jintian","class": "307","age": 19,"sex": 0,"description": ".....","is_delete":False})
db.session.commit()
print(cursor.lastrowid)  # 获取最后添加的主键ID

在这里插入图片描述

数据库查看

在这里插入图片描述

总结

本文详述了python中的SQLAlchemy操作mysql数据库的详细用法,后续在我们在flask中操作数据库就借助这个工具,非常实用,感兴趣的朋友可以一键三连,flask的高阶用法持续更新中!!!

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

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

相关文章

【Linux系统编程】第三弹---基本指令(一)

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、touch指令 2、mkdir指令 3、ls 指令 4、pwd命令 3、cd 指令 6、rmdir指令 && rm 指令 7、man指令 7、cp指令 …

在 PyCharm 中使用系统安装的 Python 和 Anaconda 的 Python什么区别

virtualenv environment &#xff1a; virtualenv 是一个用于创建独立 Python 环境的工具。它可以在同一个系统上创建多个相互独立的 Python 环境&#xff0c;每个环境都有自己的 Python 解释器和包库&#xff0c;从而可以实现不同项目之间的依赖隔离和版本控制。coda environm…

[已解决]问题:root.users.hdfs is not a leaf queue

问题&#xff1a;root.users.hdfs is not a leaf queue CDH集群报错&#xff1a; Exception in thread “main” org.apache.hadoop.yarn.exceptions.YarnException: Failed to submit application_1713149630679_0005 to YARN : root.users.hdfs is not a leaf queue 思路 …

海外媒体如何发布软文通稿

大舍传媒-带您了解海外发布新潮流 随着全球化的不断深入&#xff0c;越来越多的中国企业开始关注海外市场。为了在国际舞台上树立品牌形象&#xff0c;企业纷纷寻求与海外媒体合作&#xff0c;通过发布软文通稿的方式&#xff0c;传递正面信息&#xff0c;提升品牌知名度。作为…

【攻防世界】ics-07

<?php session_start();if (!isset($_GET[page])) {show_source(__FILE__);die(); }if (isset($_GET[page]) && $_GET[page] ! index.php) {include(flag.php); }else {header(Location: ?pageflag.php); } <?phpif ($_SESSION[admin]) {$con $_POST[con];$…

Redis: 集群

文章目录 一、单点Redis的问题二、主从架构1、概述2、集群结构3、主从数据同步原理&#xff08;1&#xff09;全量同步&#xff08;2&#xff09;增量同步 4、总结&#xff08;1&#xff09;全量同步和增量同步的区别&#xff08;2&#xff09;什么时候执行全量同步&#xff08…

绝地求生更新反作弊系统“ZAKYNTHOS”杀疯了

绝地求生的反作弊系统“ZAKYNTHOS”近期取得了显著的成绩。从2024年1月1日至3月3日&#xff0c;共有117,3588个违规账号被封禁&#xff0c;其中107,3317个账号因使用外挂而被永久封禁。 根据官方每周封禁数据公告&#xff0c;1月至3月每周的永久封禁违规账号平均数高达13万&am…

javafx实现音频播放功能

上链接&#xff1a; https://download.csdn.net/download/jasonhongcn/89146520

腾讯云幻兽帕鲁一键开服教程

腾讯云作为领先的云计算服务提供商&#xff0c;为广大用户提供了便捷、高效的游戏服务器搭建解决方案。其中&#xff0c;幻兽帕鲁一键开服功能&#xff0c;更是让游戏开服变得简单易懂。本文将为大家详细介绍腾讯云幻兽帕鲁一键开服的步骤&#xff0c;帮助大家轻松搭建自己的游…

单链表使用里面为什么是二级指针

这里很多人就会疑问&#xff0c;为什么顺序表里面是一级指针&#xff0c;单链表里面是二级指针。 这里我们专门列出来进行讲解。 因为传递的不是二级指针的话&#xff0c;会导致传参之后&#xff0c;形参改变&#xff0c;实参不改变 你希望形参改变实参也改变就必须传递地址 简…

学习javaEE的日子 Day36 字符流

Day36 1.字符流 应用场景&#xff1a;操作纯文本数据 注意&#xff1a;字符流 字节流编译器 编译器&#xff1a;可以识别中文字符和非中文字符&#xff0c;非中文字符获取1个字节&#xff08;一个字节一个字符&#xff09;&#xff0c;编译器会根据编码格式获取中文字符对应的…

企业数智化产品如何设计?

企业数智化&#xff0c;是基于新一代数字与智能技术的各类云服务&#xff0c;通过网络协同、数据智能、连接资源、重组流程、赋能组织&#xff0c;处理交易&#xff0c;执行作业&#xff0c;融入数字经济&#xff0c;推进企业业务创新&#xff08;研发、生产、营销、服务等&…

媒体邀约采访的分类?

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 媒体邀约采访可以根据不同的标准进行分类。以下是一些常见的分类方式&#xff1a; 1. 按照邀约形式&#xff1a; - 电话邀约&#xff1a;通过电话与媒体联系&#xff0c;说明采访或报道…

Gartner 《2024安全和风险管理技术路线图》:高价值技术 DSP 进入广泛部署阶段

近期&#xff0c;Gartner 发布《2024年技术采用路线图&#xff1a;安全与风险管理》&#xff08;以下简称&#xff1a;《路线图》&#xff09;&#xff0c;该信息图表识别了全球企业正在采用的 44 种与安全相关的技术&#xff0c;并根据采用阶段、部署风险和企业价值进行了映射…

Web 前端 Javascript笔记2

1、数组 为什么需要数组&#xff1a;因为变量只能存储一条数据&#xff0c;但是储存多条数据 数组的声明方式 1、new let a1new Array() console.log(a1) 2、字面量 let a2[1,2,4,"k",true,"zhangsan",11] console.log(a2) 数组里面可以存放不同的数据类…

深入理解go语言中的切片

写在文章开头 从一个Java的开发角度来看&#xff0c;切片我们可以理解为Java中的ArrayList即一种动态数组的实现&#xff0c;本文会从源码的角度对切片进行深入剖析&#xff0c;希望对你有帮助。 Hi&#xff0c;我是 sharkChili &#xff0c;是个不断在硬核技术上作死的 java …

Transformer架构实现一

从0-1搭建Transformer架构 架构图 本文主要讲解 1&#xff09;输入层的词嵌入 2&#xff09;输入层的位置编码 3&#xff09;编码层的多头注意力机制 4&#xff09;编码层的前馈全连接 1&#xff09;输入层的词嵌入 class Embeddings(nn.Module):"""构建emb…

a == 1 a== 2 a== 3 返回 true ?

1. 前言 下面这道题是 阿里、百度、腾讯 三个大厂都出过的面试题&#xff0c;一个前端同事跳槽面试也被问了这道题 // &#xff1f; 位置应该怎么写&#xff0c;才能输出 trueconst a ?console.log(a 1 && a 2 && a 3) 看了大厂的面试题会对面试官的精神…

git操作基本命令

Git命令操作&#xff1a; 1、服务器上面有新的修改&#xff0c;pull出现错误操作如下 git stash git pull origin master git stash pop 2、删除本地一个文件test.py,想重新download远程服务器最新的文件 #git checkout test.py 3、查看当前处于哪一个分支 #git …

数码相框-显示JPG图片

LCD控制器会将LCD上的屏幕数据映射在相应的显存位置上。 通过libjpeg把jpg图片解压出来RGB原始数据。 libjpeg是使用c语言实现的读写jpeg文件的库。 使用libjpeg的应用程序是以"scanline"为单位进行图像处理的。 libjpeg解压图片的步骤&#xff1a; libjpeg的使…