阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

使用Flask-SQLAlchemy管理数据库

130次阅读
没有评论

共计 1626 个字符,预计需要花费 5 分钟才能阅读完成。

一、配置数据库

1、安装扩展库

  • 安装 pymysql 扩展库

    pip install pymysql
    
  • 安装 flask-sqlalchemy 扩展库

    pip install  flask-sqlalchemy
    

    本扩展库为 flask 用于操作数据库进行 ORM 转换

2、代码配置

总体代码如下(自行进行拆分)

from flask import Flask # 导入 Flask 类 # 导入 ORM 转换库 from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) # 进行实例化 # 配置数据库 # 设置链接数据库的 URI mysql+pymysql:// 数据库用户名: 密码 @ip: 端口 / 数据库名 app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://lucky:123456@127.0.0.1:3306/lucky" # 禁止对象的修改追踪 app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False # 创建数据库对象 db = SQLAlchemy(app)

3、创建 db 三方对象

db.py

from flask_sqlalchemy import SQLAlchemy db = SQLAlchemy()

4、初始化 app 对象

app.py

from exts import db def create_app(): ... db.init_app(app)

二、设计模型

1、常见字段类型

类型名 python 类型 说明
Integer int 存储整形 32 位
SmallInteger int 小整形 16 位
BigInteger int 长整型
Float float 浮点数
String str 不定长度
Text str 大型文本
Boolean Bool Boolean
Date datetime.date 日期
Time datetime.time 时间
DateTime datetime.datetime 日期和时间
Enum Str 字符串
LargeBinary str 二进制文件

2、可选约束条件

选项 说明
primary_key 是否设置为主键 默认 False
unique 是否设置唯一索引 默认 False
index 是否设置为常规索引 默认 False
nullable 是否可以为空 默认 True
default 设置默认值

3、常用的 SQLAlchemy 关系选项

选项 说明
backref 在关系的另一模型中添加反向引用
primary join 明确指定两个模型之间使用的联结条件
uselist 如果为 False,不使用列表,而使用标量值
order_by 指定关系中记录的排序方式
secondary 指定多对多中记录的排序方式
secondary join 在 SQLAlchemy 中无法自行决定时,指定多对多关系中的二级联结条件

4、修改数据库中的表名

表名默认为模型名小写,可以在模型中添加 __tablename__ 属性来设置表名

三、分析表结构与定义模型

需求: 创建用户表

1、一个用户表所需字段

用户名 性别 年龄 简介 是否删除

2、创建模型代码位置

models 包

3、模型、属性、表之间的关联

一个模型类 对应数据库中的一张表 一个类属性 对应 表中的一个字段

4、创建用户表模型

class User(db.Model): __tablename__ = "user" # 指定表名 id = db.Column(db.Integer, primary_key=True) # 设置主键 uusername = db.Column(db.String(12)) # 用户名 最大长度 12 usex = db.Column(db.Boolean, default=True) # 性别 默认为 True uage = db.Column(db.Integer, default=18) # 年龄 默认 20 岁 uinfo = db.Column(db.String(20), default='简介') # 简介 默认简介 isDelete = db.Column(db.Boolean, default=False) # 是否删除 默认不删除

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-05-26发表,共计1626字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中