前言
flask+mysql
安装sqlalchemy
- pip安装
pip install -U Flask-SQLAlchemy
- 源码安装:
python setup.py install
两种安装方式,我使用第一种安装方式:
- 安装依赖
pip install mysqlclient
代码练习
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:[email protected]/test_flask'
- 绑定到Flask对象
db=SQLAlchemy(app)
通过此对象与数据库进行连接
在实际引用:
from flask_sqlalchemy import SQLAlchemy
报错,通过命令查看我已经成功安装了上面的库:
我现在把之前安装的库卸载以后,重新安装试一试:
pip uninstall Flask-sqlalchemy
执行如下命令试一试:
pip install flask-sqlalchemy
执行上面的命令,不是大小写的问题,那开始修改编辑器引入此模块:
原来是虚拟环境的问题,如果我们已经安装了模块,但是引用不到,需要我们耐心的查看一下是不是使用了,虚拟环境,或者是全局的环境的变量,使用:
通过重新下载库,发现已经成功了
#!/usr/bin/env python
# _*_ coding: utf-8 _*_
# @Time : 2021/6/12 10:05
# @Author : zhaocunwei
# @Version:V 0.1
# @File : sqltest.py
# @desc :
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:[email protected]/test_flask'
db = SQLAlchemy(app)
class User(db.Model):
__tablename__ = 'weibo_user'
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(64), nullable=False)
password = db.Column(db.String(256), nullable=False)
birth_date = db.Column(db.Date, nullable=True)
age = db.Column(db.Integer, default=0)
class UserAddress(db.Model):
""" 用户的地址 """
__tablename__ = 'weibo_user_addr'
id = db.Column(db.Integer, primary_key=True)
addr = db.Column(db.String(256), nullable=False)
user_id = db.Column(db.Integer, db.ForeignKey('weibo_user.id'), nullable=False)
user = db.relationship('User', backref=db.backref('address', lazy=True))
class UserAddress(db.Model):
""" 用户的地址 """
__tablename__ = 'weibo_user_addr'
id = db.Column(db.Integer, primary_key=True)
addr = db.Column(db.String(256), nullable=False)
user_id = db.Column(db.Integer, db.ForeignKey('weibo_user.id'), nullable=False)
user = db.relationship('User', backref=db.backref('address', lazy=True))
@app.route('/')
def mine():
""" 首页 """
return render_template('index.html')
@app.route('/user/<int:page>/')
def list_user(page):
""" 用户分页 """
per_page = 10 # 每一页的数据大小
# 1. 查询用户信息
user_ls = User.query
# 2. 准备分页的数据
user_page_data = user_ls.paginate(page, per_page=per_page)
return render_template('list_user.html', user_page_data=user_page_data)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。