Flask-sqlalchemy---实战

前言

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] 举报,一经查实,本站将立刻删除。

相关推荐