Я получаю сообщение об ошибке
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))