Python Flask 模型介绍和配置方法

 更新时间:2022年12月08日 11:27:36   作者:我是肿肿哦~~  
flask是基于MTV的结构,其中M指的就是模型,即数据模型,在项目中对应的是数据库,下面纪录以mysql和orm方式连接数据库的方法,对Python Flask 模型介绍和配置方法感兴趣的朋友跟随小编一起看看吧

Flask数据模型和连接数据库

flask是基于MTV的结构,其中M指的就是模型,即数据模型,在项目中对应的是数据库。flask与数据库建立联系有很多方法,但一般分为两种,一种是使用pymsql对数据库建立连接;还有一种是ORM映射的方式(基于pymysql),这种方式常用于web开发。以对象的形式与数据库表做映射,方便对象在页面中显示。下面纪录以mysql和orm方式连接数据库。

一、安装

准备工作,安装一下库:

pip3 install pymysql        建公路

pip3 install flask-sqlalchemy    实现ORM映射

pip3 install flask-migrate     发布命令工具

二、配置数据库连接、创建模型类

步骤:
(1) 配置数据库的连接路径

# mysql+pymysql://user:password@hostip:port/databasename
# 数据库+pymysql://用户名:密码@主机ip:端口/数据库名
SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:root@127.0.0.1:3306/flaskdemo'

(2) flask-sqlalchemy的搭建:在apps包下创建包ext(第三方库的配置通常建个ext文件夹存放),用于存放与数据库有关的代码,在__init__.py中添加:

   db = SQLAlchemy()   ---->必须跟app联系

在apps/init.py文件(这里我将启动app和app初始化分开了,此处的__init__是app的初始化)下与app建立联系:

   def create_app():
        ....
        # 跟app联系
        db.init_app(app)

        return app

(3) 创建模型:models.py,模型就是类,经常称作模型类

  class User(db.Model):      ------> user表
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    username = db.Column(db.String(15), nullable=False)
    password = db.Column(db.String(12), nullable=False)
    phone = db.Column(db.String(11), unique=True)
    rdatetime = db.Column(db.DateTime, default=datetime.now)

常见的数据类型:
Integer 整型
String(size) 字符串类型,务必指定大小
Text 长文本类型
DateTime 日期时间
Float 浮点类型
Boolean 布尔类型
PickleType 存储pickle类型 主要跟序列化有关
LargeBinary 存储大的二进制类型

可选的:
primary_key=True 主键
autoincrement=True 自增
nullable=False 不允许为空
unique=True 唯一
default=datetime.now 默认值 可以设置成当前系统时间或者其他的值

三、使用命令创建数据库表

a. 在app.py 中导入模型:from apps.user.models import User —》让模型与app关联
b. 在终端使用命令:db 建立数据库/更新数据库
flask db init -----》 产生一个文件夹migrations
flask db migrate -----> 自动产生了一个版本文件
flask db upgrade ------> 同步,完成数据库表创建

     项目结构
      | ---apps
      | ---ext
      | ---migrations    flask db init     只需要init一次
               |---versions   版本文件夹
                    |---71edde7ee937_.py    ---》 flask db migrate  迁移
                    |---cc0dca61130f_.py
                                                  flask  db upgrade 同步
                                                  flask  db downgrade 降级

四、以注册为例

1.创建app、migrate(绑定app、数据库),app.run启动入口

2.apps文件下__init__.py文件初始化app配置

3.数据库配置

4.创建模型类

5.通过命令创建数据库表
flask db init -----》 产生一个文件夹migrations
flask db migrate -----> 自动产生了一个版本文件
flask db upgrade ------> 同步,完成数据库表创建
此刻在pycharm的数据库视图中可以看到创建好的数据库表

6.编写注册逻辑(视图)

# 用户注册
@user_bp.route('/register', methods=['GET', 'POST'])
def register():
    if request.method == 'POST':
        username = request.form.get('username')
        password = request.form.get('password')
        repassword = request.form.get('repassword')
        phone = request.form.get('phone')
        email = request.form.get('email')
        if password == repassword:
            # 注册用户
            user = User()
            user.username = username
            # 自定义加密:new_password = hashlib.sha256(password.encode('utf-8')).hexdigest()
            # 使用自带的函数实现加密:generate_password_hash
            user.password = generate_password_hash(password)
            print(len(user.password))
            user.phone = phone
            user.email = email
            # 添加并提交
            db.session.add(user)
            db.session.commit()
            return redirect(url_for('user.index'))
    return render_template('user/register.html')

7.编写模板即html页面即可实现简单的注册功能,实现MTV的整合

到此这篇关于Python Flask 模型介绍和配置方法的文章就介绍到这了,更多相关Python Flask 模型内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python使用BeautifulSoup进行XPath和CSS选择器定位

    Python使用BeautifulSoup进行XPath和CSS选择器定位

    在 Python 中,BeautifulSoup 是一个常用的 HTML 和 XML 解析库,它允许我们轻松地定位和提取网页中的特定元素,本文将详细介绍如何在 BeautifulSoup 中使用 XPath 和 CSS 选择器定位 HTML 元素,并提供示例代码以帮助新手理解这些概念,需要的朋友可以参考下
    2024-11-11
  • python-pymongo常用查询方法含聚合问题

    python-pymongo常用查询方法含聚合问题

    这篇文章主要介绍了python-pymongo常用查询方法含聚合问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • python基础之while循环、for循环详解及举例

    python基础之while循环、for循环详解及举例

    所谓循环结构就是程序中控制某条或某些指令重复执行的结构,下面这篇文章主要给大家介绍了关于python基础之while循环、for循环的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • 如何通过神经网络实现线性回归的拟合

    如何通过神经网络实现线性回归的拟合

    这篇文章主要介绍了如何通过神经网络实现线性回归的拟合问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • 解决安装sklearn包失败问题

    解决安装sklearn包失败问题

    这篇文章主要介绍了解决安装sklearn包失败问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-10-10
  • SQLAlchemy的主要组件详细讲解

    SQLAlchemy的主要组件详细讲解

    SQLAlchemy是一个基于Python实现的ORM框架,能满足大多数数据库操作需求,同时支持多种数据库引擎(SQLite,MySQL,Postgresql,Oracle等),这篇文章主要介绍了SQLAlchemy的主要组件有哪些,本文给大家介绍的非常详细,对大家的学习具有一定的参考借鉴价值,需要的朋友可以参考
    2023-08-08
  • 关于python之字典的嵌套,递归调用方法

    关于python之字典的嵌套,递归调用方法

    今天小编就为大家分享一篇关于python之字典的嵌套,递归调用方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-01-01
  • 使用Python编写Linux系统守护进程实例

    使用Python编写Linux系统守护进程实例

    这篇文章主要介绍了使用Python编写Linux系统守护进程实例,本文先是讲解了什么是守护进程,然后给出了一个Python语言的简单实现,需要的朋友可以参考下
    2015-02-02
  • python安装cxOracle避坑总结不要直接pip install

    python安装cxOracle避坑总结不要直接pip install

    这篇文章主要为大家介绍了python安装cx_Oracle是遇到的一些问题的解决办法的总结,来帮大家避避坑有需要的朋友可以借鉴参考下,希望能够有所帮助祝大家多多进步
    2021-10-10
  • Python中虚拟环境依赖问题的解决方案详解

    Python中虚拟环境依赖问题的解决方案详解

    在Python开发中,虚拟环境和依赖管理是必不可少的工具,本文将以一个实际案例为基础,详细分析如何解决Python虚拟环境中的依赖问题,希望对大家有所帮助
    2025-03-03

最新评论