|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 18752016699 于 2020-4-7 01:56 编辑
自学flask遇到了一个相当棘手的问题,SQLAlchemy无法与MySQL连接,在flask中运行了创建数据库操作后,MySQL中没有反应,也无报错,请教一下鱼友们,万分感谢
app.py中的代码
- from flask import Flask
- from flask_sqlalchemy import SQLAlchemy
- #下面两条从弹幕中学的
- import pymysql
- pymysql.install_as_MySQLdb()
- app = Flask(__name__)
- # 配置数据库的地址
- app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:1234@127.0.0.1:3306/flask_sql_demo'
- # 跟踪数据库的修改 ---> 不建议修改 未来的版本会移除
- app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
- app.config['SECRET_KEY']='kfkj'
- db = SQLAlchemy(app)
- '''
- 两张表
- 角色(管理员/普通用户)
- 用户(角色ID)
- '''
- # 数据库的模型,需要继承db.Model
- class Role(db.Model):
- # 定义表名
- __tablename__ = 'roles'
- # 定义字段
- # db.Column表示是一个字段
- id = db.Column(db.Integer,primary_key=True)
- name = db.Column(db.String(16),unique=True)
- class Users(db.Model):
- __tablename__ = 'users'
- id = db.Column(db.Integer,primary_key=True)
- name = db.Column(db.String(16),unique=True)
- # db.ForeignKey('roles.id') 表示是外键,表名.id
- role_id = db.Column(db.Integer,db.ForeignKey('roles.id'))
- @app.route('/')
- def hello_world():
- return 'Hello World!'
- if __name__ == '__main__':
- # 删除表
- db.drop_all()
- # 创建表
- db.create_all(app=app)
- app.run()
复制代码
我的软件及版本分别是:
python:3.8 32bit
pycharm:2018.3.7
MySQL:5.7.22
windows7 32位操作系统
视频资料地址:https://www.bilibili.com/video/BV17W41177oE
p20 04-03-数据库的基本操作1-增删改 02:15处的操作无法实现
p.s.如果MySQL不推荐使用的话,有什么比较适合初学者的数据库吗? |
|