Ошибка после переноса приложения flask в Heroku из sqlite в Postgresql - PullRequest
0 голосов
/ 16 апреля 2020

Я получаю сообщение об ошибке

sqlalchemy.exc.IntegrityError: (psycopg2.errors.NotNullViolation) null value in column "id" violates not-null constraint

после переноса моего приложения flask с этапа разработки на этап производства, который работает с дополнением Heroku Postgresql

Может кто-нибудь помочь ? Уже созданные пользователи таблиц, использующие pgAdmin4. Должен ли я изменить первичный ключ на имя пользователя? Функция автоинкремента идентификатора не работает

Вот мой файл models.py моего приложения

from werkzeug.security import generate_password_hash, check_password_hash
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
from flask import current_app

from . import db, login_manager
from flask_login import UserMixin

class User(UserMixin, db.Model):
    __tablename__ = 'users'
    id            = db.Column(db.Integer, primary_key = True, autoincrement=True)
    name          = db.Column(db.String(20), nullable = False)
    last_name     = db.Column(db.String(20), nullable = False)
    user_name     = db.Column(db.String(20), nullable = False, unique = True)
    email         = db.Column(db.String(30), nullable = False, unique = True)
    password_hash = db.Column(db.String(128), nullable = False)
    send_emails   = db.Column(db.Boolean, default = True)
    confirmed     = db.Column(db.Boolean, default = False)


    def generate_confirmation_token(self, expiration = 3600):
        s = Serializer(current_app.config['SECRET_KEY'], expiration)
        return s.dumps({'confirm': self.id})

    def confirm(self, token):
        s = Serializer(current_app.config['SECRET_KEY'])
        try:
            data = s.loads(token)
        except:
            return False

        if data.get('confirm') != self.id:
            return False

        self.confirmed = True
        db.session.add(self)

        return True

    def __repr__(self):
        return 'User: ' + str(self.user_name) + ', Id: ' + str(self.id)

@login_manager.user_loader
def load_user(user_id):
    return User.query.get(int(user_id))



Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...