python - flask测试登录时shell返回table users has no column named email?
PHP中文网
PHP中文网 2017-04-17 17:32:50
[Python讨论组]

shell中输入

>>> u = User(email='xxxxxxxxx@qq.com', username='john', password='cat')
>>> db.session.add(u)
>>> db.session.commit()

shell中返回

OperationalError: (sqlite3.OperationalError) table users has no column named email [SQL: u'INSERT INTO users (email, username, password_hash, role_id) VALUES (?, ?, ?, ?)'] [parameters: ('xxxxxxxxxxx@qq.com', 'john', 'pbkdf2:sha1:1000$khpKtr7A$1813eebe6db38296c170b160cff6c92f41129ecd', None)]

感觉models.py里数据表中数据添加email这个字段了啊
models.py里代码如下:

from werkzeug.security import generate_password_hash,check_password_hash
from flask.ext.login import UserMixin
from . import db,login_manager
class Role(db.Model):
    __tablename__ = 'roles'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(64), unique=True)
    users = db.relationship('User', backref='role', lazy='dynamic')

    def __repr__(self):
        return '<Role %r>' % self.name

class User(UserMixin,db.Model):
    __tablename__ = 'users'
    id = db.Column(db.Integer, primary_key=True)
    email=db.Column(db.String(64),unique=True,index=True)
    username = db.Column(db.String(64), unique=True, index=True)
    password_hash=db.Column(db.String(128))
    role_id = db.Column(db.Integer, db.ForeignKey('roles.id'))
  
    @property
    def password(self):
        raise AttributeError('password is not a readable attribute')

    @password.setter
    def password(self,password):
        self.password_hash=generate_password_hash(password)

    def verify_password(self,password):
        return check_password_hash(self.password_hash,password)

    def __repr__(self):
        return '<User %r>' % self.username

@login_manager.user_loader
def load_user(user_id):
    return User.query.get(int(user_id))
PHP中文网
PHP中文网

认证0级讲师

全部回复(2)
PHP中文网

增加email字段时,你有相应更新表吗?

PHP中文网

更新表后,运行db.commit.rollback(),然后再db.session.commit()

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号