组团学

使用Flask-SQLAlchemy管理数据库

阅读 (168982)

一、配置数据库

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) # 是否删除 默认不删除
需要 登录 才可以提问哦