Flask小项目实战笔记

本文记录了在使用Flask进行小项目实战时遇到的数据库配置问题,包括创建数据库时设置charset,以及Flask与MYSQL配置时的常见错误。通过参考链接提供的解决方案,主要强调了`db = SQLAlchemy(app)`需置于`app.config`之后,无密码时MySQL连接格式,以及项目中的逻辑代码和网页代码部分。
摘要由CSDN通过智能技术生成

1.创建数据库时设置charset

CREATE DATABASE dbname DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

2.Flask MYSQL配置时出错

#报错信息
UserWarning: Neither SQLALCHEMY_DATABASE_URI nor SQLALCHEMY_BINDS is set. Defaulting SQLALCHEMY_DATABASE_URI to "sqlite:///:memory:".
  'Neither SQLALCHEMY_DATABASE_URI nor SQLALCHEMY_BINDS is set. '

FSADeprecationWarning: SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and will be disabled by default in the future.  Set it to True or False to suppress this warning.
  'SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and '

解决方法:
https://blog.csdn.net/zhongqiushen/article/details/79139346
https://segmentfault.com/q/1010000008767533/a-1020000008769064
https://blog.csdn.net/weixin_41085315/article/details/79813858

主要就是:
1. db = SQLAlchemy(app) 要在 app.config[ ] 后
2. 没有密码时候直接写成 root:@127.0.0.1:3306

3.逻辑代码


# B站黑马 Flask 实战小项目

from flask import Flask, render_template, flash, request, redirect, url_for
from flask_sqlalchemy import SQLAlchemy

from flask_wtf import FlaskForm
from wtforms import StringField, SubmitField
from wtforms.validators import DataRequired

app = Flask(__name__)

'''
整体实现思路:
1.配置数据库
2.添加模型
3.添加数据
4.使用模板显示数据库查询的数据
    # a.查询所有的作者信息,让信息传递给模板
    # b.模板中按照格式,依次for循环作者和书籍即可
5.使用WTF显示表单
    # a.自定义表单类
    # b.模板中显示
    # c.secret_key / 编码 / csrf_token
6.使用相关的增删逻辑
    # a.增加数据
    # b.删除书籍 (网页中删除-点击需要发送书籍的ID给删除书籍的路由-路由需要接收参数)
    # c.删除作者 
'''

# 第一步 配置数据库
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:@localhost:3306/books'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
app.secret_key = 'itheima'

db = SQLAlchemy(app)

# 第二步 定义书和作者模型

# 1.作者模型

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值