flask 数据库迁移可能出现的六大问题,生成requirements文件夹方式,flask项目复写,

今日任务

项目分级显示

— app

— — admin 代表

— — auth 代表用户的点赞 评论 登录等等

— — blog 代表blog的网页

首先单独把auth运行出来

第一步

1. 生成requirements文件夹
2.在一个新的虚拟环境里面完成requirements依赖下载
3.完成项目的复写

1. 生成requirements文件夹

方法一:整个环境下的安装包都保存到requirements.txt中
pip freeze > requirements.txt

​ 作用范围:pip的freeze命令保存了保存当前Python环境下所有类库包,包括那些你没有在当前项目中使用的类库。 (如果你没有的virtualenv)
​ 生成的requirements.txt:速度非常快,不到1s
​ 作用范围:当前项目使用的类库导出生成为requirements.txt。

方法二:只生成单个项目中的使用到的安装包
使用方法:pipreqs 加上当前路径即可。在导出当前项目使用的类库时,先定位到项目根目录,然后调用 pipreqs ./ --encoding=utf8 命令,该命令避免编码错误,并自动在根目录生成 ```requirements.txt```文件。
pip install pipreqs
pipreqs .

生成的requirements.txt:有点慢,耗时1m多

原文链接:https://blog.csdn.net/pearl8899/article/details/113877334

1.先创建环境 在建立项目

photo
在建立flask项目的时候选择现有的虚拟环境

photo
photo
auth文件夹下的db是通过init.py来的,init.py的db是通过.auth.py来导入db的

from datetime import datetime
from RealProject import dbclass BaseModel(db.Model):__abstract__ = True# 创建时间add_date = db.Column(db.DateTime,nullable=False,default =datetime.now)# 更新时间pub_date = db.Column(db.DateTime,default =datetime.now,onupdate=datetime.now, nullable=False)class User(BaseModel):# 用户模型的主键user_id = db.Column(db.Integer, primary_key=True)# 每个用户的唯一用户名,不可为空username = db.Column(db.String(128), unique=True, nullable=False)# 用户密码,不可为空password = db.Column(db.String(320), nullable=False)# 用户性别,可为空gender = db.Column(db.String(6), nullable=True)  # 性别# 用户头像 URL,可为空avatar = db.Column(db.String(200), nullable=True)  # 头像# 用户电子邮件,可为空email = db.Column(db.String(45), nullable=True)  # 邮箱# 用户个性签名,可为空sign = db.Column(db.String(30), nullable=True)  # 个性签名# 用户个人介绍,可为空introduce = db.Column(db.String(200), nullable=True)  # 个人介绍# 标识用户是否为超级管理员,可为空,默认为 Falseis_super_user = db.Column(db.Boolean, nullable=True, default=False)  # 超级管理员标识# 标识用户是否活跃,可为空,默认为 Trueis_active = db.Column(db.Boolean, nullable=True, default=True)  # 是否为活跃用户# 标识用户是否允许登录到后台,可为空,默认为 Falseis_staff = db.Column(db.Boolean, nullable=True, default=False)  # 是否允许登录后台# 与 'Post' 模型的关系,关联的帖子级联删除post = db.relationship('Post', back_populates='user', cascade="all,delete", passive_deletes=True)# 与 'Answer' 模型的关系,关联的回答级联删除answer = db.relationship('Answer', back_populates='user', cascade="all,delete", passive_deletes=True)# 与 'Collection' 模型的关系,关联的收藏级联删除collection = db.relationship('Collection', back_populates='user', cascade="all,delete", passive_deletes=True)# 与 'Comment' 模型的关系,关联的评论级联删除comment = db.relationship('Comment', back_populates='user', cascade="all,delete", passive_deletes=True)# 打印或作为字符串使用时,用户对象的表示def __repr__(self):return '<User %r>' % self.username

__repr__ 函数是 Python 类中的一个特殊方法,用于提供对象的字符串表示。在这里,它返回一个字符串,格式为 <User %r>,其中 %r 会用 User 对象的 username 属性替换。这种表示对于调试和日志记录很有用。例如,如果你打印一个 User 对象,你会看到类似 <User 'john_doe'> 的输出。

model.py写好后进行数据库迁移操作

在terminal终端写入三段话

flask db initflask db migrate
flask db upgrade
flask 数据库迁移可能出现的问题

photo
photo
成功运行应该会出现detect xxx table

photo
photo
photo
Flask迁移mysql数据库报错汇总_error:root:-CSDN博客

在完成执行flask db migrate会在version下面出现一个py函数, 就说明flask db migrate 运行成功,接下来运行flask db upgrade就可

photo
对于一个大项目来说,迁移数据库的时候一定要在manage.py中导入model.py文件就可以

photo
对于一个大项目来说,迁移数据库的时候一定要在manage.py中导入model.py文件就可以

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/256823.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

js/jQuery常见操作 之 jQuery操作复选框的常见问题

js/jQuery常见操作 之 jQuery操作复选框的常见问题 1. js/jQuery的其他一些常见基础操作2. 全选/全不选问题2.1 效果2.2 实现代码2.2.1 简单js实现2.2.2 jQuery实现2.2.2.1 注意语法&#xff08;区别jQuery版本&#xff09;2.2.2.2 完整代码实现 3. jQuery实现点击 行tr 实现ch…

OpenCV交叉编译

1.下载代码解压 tar -zxvf opencv-4.8.1.tar.gz cd cd opencv-4.8.1 sudo mkdir chmod 777 build cd build 2.配置交叉编译工具 根据自己的板子进行修改 -D CMAKE_C_COMPILERaarch64-mix210-linux-gcc -D CMAKE_CXX_COMPILERaarch64-mix210-linux-g 3.cmake生成makefi…

C#winform上下班打卡系统Demo

C# winform上下班打卡系统Demo 系统效果如图所示 7个label控件(lblUsername、lblLoggedInEmployeeId、lab_IP、lblCheckOutTime、lblCheckInTime、lab_starttime、lab_endtime)、3个按钮、1个dataGridView控件、2个groupBox控件 C#代码实现 using System; using System.Dat…

WEB组态编辑器(BY组态)介绍

BY组态是一款非常优秀的纯前端的【web组态插件工具】&#xff0c;可无缝嵌入到vue项目&#xff0c;react项目等&#xff0c;由于是原生js开发&#xff0c;对于前端的集成没有框架的限制。同时由于BY组态只是一个插件&#xff0c;不能独立运行&#xff0c;必须嵌入到你方软件平台…

【EI征稿中|ACM出版】2023 人工智能、系统与网络安全国际学术会议 (AISNS 2023)

2023 人工智能、系统与网络安全国际学术会议 (AISNS 2023&#xff09; 2023 International Conference on Artificial Intelligence, Systems and Network Security 由西南科技大学计算机科学与技术学院主办的2023人工智能、系统与网络安全国际学术会议 (AISNS 2023&#xff…

自动数据增广论文笔记 | AutoAugment: Learning Augmentation Strategies from Data

谷歌大脑出品 paper: https://arxiv.org/abs/1805.09501 这里是个论文的阅读心得&#xff0c;笔记&#xff0c;不等同论文全部内容 文章目录 一、摘要1.1 翻译1.2 笔记 二、(第3部分)自动增强:直接在感兴趣的数据集上搜索最佳增强策略2.1 翻译2.2 笔记 三、跳出论文&#xff0c…

UE蓝图 里的函数,编辑模式在Sequence里执行

在蓝图里创建CustomFunction &#xff0c;把蓝图拖入Sequence &#xff0c;添加事件 即可调用 如果需要在Sequence里K 蓝图里的变量&#xff0c;需要勾上向过场动画公开

第十四章 : Spring Boot 整合spring-session,使用redis共享

第十四章 &#xff1a; Spring Boot 整合spring-session,使用redis共享 前沿 本文重点讲述&#xff1a;spring boot工程中使用spring-session机制进行安全认证&#xff0c;并且通过redis存储session&#xff0c;满足集群部署、分布式系统的session共享。 基于SPringBoot 2.3.2…

uni-app 微信小程序之好看的ui登录页面(二)

文章目录 1. 页面效果2. 页面样式代码 更多登录ui页面 uni-app 微信小程序之好看的ui登录页面&#xff08;一&#xff09; uni-app 微信小程序之好看的ui登录页面&#xff08;二&#xff09; uni-app 微信小程序之好看的ui登录页面&#xff08;三&#xff09; uni-app 微信小程…

最新版本——Hadoop3.3.6单机版完全部署指南

大家好&#xff0c;我是独孤风&#xff0c;大数据流动的作者。 本文基于最新的 Hadoop 3.3.6 的版本编写&#xff0c;带大家通过单机版充分了解 Apache Hadoop 的使用。本文更强调实践&#xff0c;实践是大数据学习的重要环节&#xff0c;也能在实践中对该技术有更深的理解&…

如何使用ArcGIS Pro制作类似CAD的尺寸注记

经常使用CAD制图的朋友应该比较熟悉CAD内的尺寸标注&#xff0c;这样的标注看起来直观且简洁&#xff0c;那么在ArcGIS Pro内能不能制作这样尺寸注记呢&#xff0c;答案是肯定的&#xff0c;这里为大家介绍一下制作的方法&#xff0c;希望能对你有所帮助。 数据来源 本教程所…

node.js和浏览器之间的区别

node.js是什么 Node.js是一种基于Chrome V8引擎的JavaScript运行环境&#xff0c;可以在服务器端运行JavaScript代码 Node.js 在浏览器之外运行 V8 JavaScript 引擎。 这使得 Node.js 非常高效。 浏览器如何运行js代码 nodejs运行环境 在浏览器中&#xff0c;大部分时间你所…