Flask-SQLAlchemy常用字段介绍

前言

这几年一直在it行业里摸爬滚打,一路走来,不少总结了一些python行业里的高频面试,看到大部分初入行的新鲜血液,还在为各样的面试题答案或收录有各种困难问题

于是乎,我自己开发了一款面试宝典,希望能帮到大家,也希望有更多的Python新人真正加入从事到这个行业里,让python火不只是停留在广告上。

微信小程序搜索:Python面试宝典

或可关注原创个人博客:https://lienze.tech

也可关注微信公众号,不定时发送各类有趣猎奇的技术文章:Python编程学习

Flask-SQLAlchemy

SQLAlchemy是一个ORM框架,可以不局限于框架或位置使用

而Flask-SQLAlchemy是一个Flask扩展,简化了在Flask程序中使用SQLAlchemy的操作,并且可以支持多种数据库后台


扩展安装

pip3 install Flask-SQLAlchemy
pip3 install flask-migrate
pip3 install flask_script
pip3 install mysqlclient

迁移集成

默认的Flask-SQLAlchemy并不能像django的orm一样,进行动态迁移,改变数据库状态,只能使用对象db的.create_all等方法进行数据库的管理

因此我们使用flask-migrate就解决这个问题,flask-migrate可以直接将修改的东西映射到数据库中,这一小节首先配置flask-migrate


首先我们创建一个最基本的含有蓝图的项目结构用来实现一个简单实用Flask-SQLAlchemy结合flask-migrate使用的例子

并且采用工厂模式创建flask应用对象,下面是目录结构

flaskProject/
	ext.py
	manage.py
	settings.py
	app.py
	user/
		__init__.py
		models.py
		views.py
  • ext.py

    扩展插件,数据库配置文件,单独写入该文件下,避免循环引入

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()
  • manage.py

    命令行管理文件,在这个文件进行app的manager初始化,migrate命令的支持添加等等

from flask_migrate import Migrate, MigrateCommand
from ext import db
from flask_script import Manager
from app import create_app

app = create_app() # 实例化flask的app对象
manager = Manager(app)  # 实例化一个manager对象
Migrate(app, db)  # 迁移命令管理与app,建立关系

manager.add_command('db', MigrateCommand)  # 添加迁移命令集 到脚本命令

if __name__ == '__main__':
    manager.run()
  • app.py

    代码入口文件,进行配置选择,蓝图注册,服务启动等功能

from flask import Flask
from ext import db


def create_app(config="settings.py"):
    app = Flask(__name__)
    app.config.from_pyfile(config)

    from user.views import user_blueprint
    app.register_blueprint(user_blueprint)

    db.init_app(app)
    return app


if __name__ == '__main__':
    app = create_app()
    app.run()
  • settings.py

    配置文件,用来存放项目配置、数据库连接等有关数据

其余配置项参考: https://flask-sqlalchemy.palletsprojects.com/en/2.x/config/#configuration-keys

# 设置连接数据库的URL
SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:mysql@127.0.0.1:3306/flasktest'
# 设置每次请求结束后会自动提交数据库中的改动
SQLALCHEMY_COMMIT_ON_TEARDOWN = True
# 如果设置为True,Flask-SQLAlchemy将跟踪对象的修改并发出信号。默认值为None
SQLALCHEMY_TRACK_MODIFICATIONS = True
# 查询时会显示原始SQL语句
SQLALCHEMY_ECHO = True

数据库连接URL配置参考

dialect+driver://username:password@host:port/database
参数名解释
SQLALCHEMY_DATABASE_URI用于连接的数据库 URI 。例如:sqlite:tmp/test.dbmysql://username:password@server/db
SQLALCHEMY_BINDS一个映射 binds 到连接 URI 的字典。更多 binds 的信息见用 Binds 操作多个数据库
SQLALCHEMY_ECHO如果设置为Ture, SQLAlchemy 会记录所有 发给 stderr 的语句,这对调试有用。(打印sql语句)
SQLALCHEMY_RECORD_QUERIES可以用于显式地禁用或启用查询记录。查询记录 在调试或测试模式自动启用。更多信息见get_debug_queries()。
SQLALCHEMY_NATIVE_UNICODE可以用于显式禁用原生 unicode 支持。当使用 不合适的指定无编码的数据库默认值时,这对于 一些数据库适配器是必须的(比如 Ubuntu 上 某些版本的 PostgreSQL )。
SQLALCHEMY_POOL_SIZE数据库连接池的大小。默认是引擎默认值(通常 是 5 )
SQLALCHEMY_POOL_TIMEOUT设定连接池的连接超时时间。默认是 10 。
SQLALCHEMY_POOL_RECYCLE多少秒后自动回收连接。这对 MySQL 是必要的, 它默认移除闲置多于 8 小时的连接。注意如果 使用了 MySQL , Flask-SQLALchemy 自动设定 这个值为 2 小时。
建表

找到app的models文件夹下,使用ext目录下初始化好的db对象进行orm表的编写

class Users(db.Model):
    __tablename__ = 'users'

    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(32), index=True, nullable=False)
    age = db.Column(db.String(2), index=True, nullable=False)

    def __init__(self, name, age):
        self.name = name
        self.age = age
引入模型

建立好的表,为了能够让flask-migrate捕捉到模型类上下文变化,需要在manage.py文件中引入app下的models文件

from user import models  # 导入你想要迁移的数据表的ORM类
执行迁移
  • 初始化,只执行一次

python3 manage.py db init

  • 生成迁移文件,等同于django的makemigartions

python3 manage.py db migrate

  • 迁移

python3 manage.py db upgrade


  • 返回之前数据库版本

python3 manage.py db history

输出格式:<base> ->  版本号 (head), initial migration
  • 回滚到指定版本

python3 manage.py db downgrade 版本号

常用字段

类型名python中类型说明
Integerint普通整数,一般是32位
SmallIntegerint取值范围小的整数,一般是16位
BigIntegerint或long不限制精度的整数
Floatfloat浮点数
Numericdecimal.Decimal普通整数,一般是32位
Stringstr变长字符串
Textstr变长字符串,对较长或不限长度的字符串做了优化
Unicodeunicode变长Unicode字符串
UnicodeTextunicode变长Unicode字符串,对较长或不限长度的字符串做了优化
Booleanbool布尔值
Datedatetime.date时间
Timedatetime.datetime日期和时间
LargeBinarystr二进制文件

常用字段选项

选项名说明
primary_key如果为True,代表表的主键
unique如果为True,代表这列不允许出现重复的值
index如果为True,为这列创建索引,提高查询效率
nullable如果为True,允许有空值,如果为False,不允许有空值
default为这列定义默认值

常用关系选项

选项名说明
backref在关系的另一模型中添加反向引用
primary join明确指定两个模型之间使用的联结条件
uselist如果为False,不使用列表,而使用标量值
order_by指定关系中记录的排序方式
secondary指定多对多关系中关系表的名字
secondary join在SQLAlchemy中无法自行决定时,指定多对多关系中的二级联结条件
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Flask 中调用数据库,需要先安装相应的数据库驱动,比如 MySQL,SQLite,PostgreSQL 等。这里以 SQLite 为例。 首先,需要安装 SQLite3: ```bash sudo apt-get install sqlite3 ``` 然后,在 Flask 中引入 sqlite3 模块: ```python import sqlite3 ``` 使用 sqlite3 模块创建数据库连接: ```python conn = sqlite3.connect('example.db') ``` 其中,example.db 是数据库文件名。如果该文件不存在,则会自动创建。如果已经存在,则会打开该文件并返回一个连接对象。 接下来,可以使用连接对象创建游标对象: ```python cur = conn.cursor() ``` 使用游标对象执行 SQL 语句: ```python cur.execute("CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, email TEXT)") ``` 上面的 SQL 语句创建了一个名为 users 的表,该表包含三个字段:id,name 和 email。 插入数据: ```python cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('John', 'john@example.com')) ``` 查询数据: ```python cur.execute("SELECT * FROM users") rows = cur.fetchall() ``` 上面的代码查询了 users 表中的所有数据,并将结果存储在 rows 变量中。可以将 rows 变量传递给模版,然后在模版中渲染数据。 完整的示例代码如下: ```python from flask import Flask, render_template import sqlite3 app = Flask(__name__) @app.route('/') def index(): conn = sqlite3.connect('example.db') cur = conn.cursor() cur.execute("CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, email TEXT)") cur.execute("INSERT INTO users (name, email) VALUES (?, ?)", ('John', 'john@example.com')) cur.execute("SELECT * FROM users") rows = cur.fetchall() return render_template('index.html', rows=rows) if __name__ == '__main__': app.run(debug=True) ``` 在上面的代码中,将查询结果 rows 传递给模版 index.html: ```html <!DOCTYPE html> <html> <head> <title>Flask Template with Database</title> </head> <body> <h1>Flask Template with Database</h1> <table> <thead> <tr> <th>ID</th> <th>Name</th> <th>Email</th> </tr> </thead> <tbody> {% for row in rows %} <tr> <td>{{ row[0] }}</td> <td>{{ row[1] }}</td> <td>{{ row[2] }}</td> </tr> {% endfor %} </tbody> </table> </body> </html> ``` 在模版中使用 for 循环遍历查询结果 rows,并将每一行的数据显示在表格中。 运行程序,访问 http://localhost:5000,即可看到查询结果在网页中显示。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李恩泽的技术博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值