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

这篇具有很好参考价值的文章主要介绍了【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

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

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

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

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

ORM

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

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

优点:

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

缺点:

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

flask与python原生操作数据库流程对比
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

Flask-SQLAlchemy

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

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

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

安装 flask-sqlalchemy

pip install flask-sqlalchemy

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

如果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",    # 如果底层驱动是MysqlDB
    echo=True, # 当设置为True时会将orm语句转化为sql语句打印,一般debug的时候可用
    pool_size=8, # 连接池的大小,默认为5个,设置为0时表示连接无限制
    pool_recycle=60*30 # 设置时间以限制数据库多久没连接自动断开,单位是秒
)

#创建会话连接
DbSession = sessionmaker(bind=engine)
session = DbSession()

# 创建数据基类
Model = declarative_base()

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

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语句
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

查看数据库,有创建我们指定的表
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

看下表结构
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

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

添加数据

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

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

数据库查看
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

添加多条数据

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()

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

在数据库中查看
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

查询所有数据

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

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

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

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

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

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

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

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

查询不存在的id,返回为None
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

所以,查询之前要做个判断
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

按条件查询

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)

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

更新一条数据

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

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

查看数据库,可见id为3的记录名字已被修改
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

更新多条数据

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

先看下更新之前,班级为305的学生的年龄都是18岁
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

执行之后
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

年龄被修改
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

删除一条数据

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

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

id为3的数据被删除
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

删除多条数据

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

删除之前,我们先添加些数据
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

执行删除
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

可见班级为304的数据已被删除
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

执行原生sql语句

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

此时,会报如下错误
【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

出错原因:是因为因为安装的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)

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

#获取多条

data_list = cursor.fetchall()
print(data_list)

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

写[添加、删除、修改]

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】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

数据库查看

【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战,flask框架零基础,进阶应用实战教学,python,flask,数据库,SQLAlchemy,flask操作数据库

总结

本文详述了python中的SQLAlchemy操作mysql数据库的详细用法,后续在我们在flask中操作数据库就借助这个工具,非常实用,感兴趣的朋友可以一键三连,flask的高阶用法持续更新中!!!文章来源地址https://www.toymoban.com/news/detail-854370.html

到了这里,关于【python】flask操作数据库工具SQLAlchemy,详细用法和应用实战的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • python:使用Flask-SQLAlchemy对数据库增删改查的简单示例

    以下将介绍Flask-SQLAlchemy对数据库增删改查的简单示例。 一、安装所需的库 pip install flask flask-sqlalchemy flask-mysql 二、创建数据表 本示例使用mysql创建数据库和表 CREATE TABLE `user` (   `id` int(11) NOT NULL AUTO_INCREMENT,   `name` varchar(255) DEFAULT NULL,   `age` int(11) DEFAULT NULL,   PRIMARY KEY (`id

    2024年02月07日
    浏览(67)
  • Flask-数据库-SQLAlchemy

    SQLAlchemy是flask的扩展,是一个功能强大的OR映射器,支持多种数据库后台,可以将类的对象映射至数据库表。 使用这个工具,可以创建数据库,创建表,并为数据库添加数据,进行查询操作等。 参考:Flask SQLAlchemy - Flask 教程 | BootWiki.com  app=Flask(__name__)  #创建Flask实例  app

    2023年04月09日
    浏览(41)
  • Flask数据库之SQLAlchemy--介绍--链接数据库

    目录 SQLAlchemy介绍 SQLAlchemy连接数据库  数据库是一个网站的基础!!! 比如MySQL、MongoDB、SQLite、PostgreSQL等,这里我们以MySQL为例进行讲解。 SQLAlchemy是一个ORM框架 对象关系映射 (英语: Object Relational Mapping ,简称 ORM ,或 O/RM ,或 O/R mapping ),是一种程序设计技术,用于实

    2024年02月07日
    浏览(61)
  • Flask-sqlalchemy更新数据库

    Flask开发过程中,难免不会在开发工程中修改数据库信息,如添加字段,修改字段类型等,Flask可以通过扩展库flask-migrate来更新DEBUG中的工程数据库,更新数据库步骤如下: 1、首先需要安装flask_migrate,pip install flask_migrate 2、因为flask_sqlalchemy是通过终端命令更新,所以需要f

    2023年04月08日
    浏览(40)
  • flask-sqlalchemy连接数据库

    1、安装flask_sqlalchemy和pymysql包 2、进行配置 使用Flask-SQLAlchemy扩展操作数据库,首先需要通过URL建立数据库连接,必须保存到Flask配置对象的SQLALCHEMY_DATABASE_URI中。 其中HOSTNAME为路由地址 PORT为端口号,我在创建数据库时没有更改,所以用的默认的3306端口号 DATABASE为数据库名字

    2024年02月06日
    浏览(62)
  • 简单易用,灵活强大:用SQLAlchemy实现Python操作数据库

    什么是SQLAlchemy? SQLAlchemy是一个Python的SQL工具和ORM框架,可以通过Python代码直接操作关系型数据库,也可以使用ORM模型进行对象关系映射。它支持多种数据库,并提供了强大的SQL表达式和查询API。 SQLAlchemy可以分为两个部分:Core和ORM。 Core:提供了底层的SQL表达式和查询API,

    2024年02月04日
    浏览(73)
  • python Flask项目使用SQLalchemy连接数据库时,出现RuntimeError:Working outside of application context.的解决过程记录

    在使用python的Flask框架跟着教程编写项目时,我跟着教程使用了三个文件来组织,分别是main.py(主程序),module.py(数据库模型),controller.py(蓝图模块程序,用Blueprint衔接) 在主程序中,创建app、SQLalchemy实例对象db并将二者绑定 在module.py中,导入主程序中的db和app,创建

    2024年02月09日
    浏览(47)
  • Python 进阶(三):Python使用ORM框架SQLAlchemy操作Oracle数据库

    要详细连接Oracle数据库并使用SQLAlchemy进行操作,按照以下步骤进行配置和编写代码: Oracle Instant Client:Oracle 提供的客户端库,可用于在 Python 中连接和操作 Oracle 数据库 访问 Oracle 官方网站:前往 Oracle 官方网站(instant-client/winx64-64-downloads) 可能需要创建一个免费的 Oracle

    2024年02月11日
    浏览(48)
  • Python SQL 数据库操作利器:SQLAlchemy 库详解(看这一篇文章就够了)

    引言: Python 是一门广受欢迎的编程语言,而 SQL 则是用于管理和操作数据库的标准查询语言。SQLAlchemy 是一个功能强大的 Python 库,它提供了一种与多种数据库进行交互的灵活方式。本文将介绍 SQLAlchemy 库,并以九个重要的要点详细解释其功能和用法。 SQLAlchemy 简介 SQLAlchem

    2024年02月07日
    浏览(66)
  • Python(Web时代)—— Flask的数据库操作

    SQLAlchamy  是 Python 中一个通过 ORM 操作数据库的框架 SQLAlchemy(对象关系映射器)提供了一种方法,用于将用户定义的Python类与数据库表相关联,并将这些类(对象)的实例与其对应表中的行相关联。 简单理解:   创建一个类,一个类对应了一个数据库中的一张表,类的属性

    2024年01月22日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包