繁体   English   中英

Flask-sqlalchemy独特的禁令不起作用

[英]Flask-sqlalchemy unique contraint not working

我试图找出为什么字段的“唯一”约束不起作用。 我正在使用Flask,SQLAlchemy和Sqlite。

考虑一下模型:

from app import db
from flask_login import UserMixin

class User(UserMixin, db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(64), unique=True)
    password = db.Column(db.String(64))
    email = db.Column(db.String(120), unique=True)

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

我希望,因为在用户名字段上有一个唯一的约束,它不允许我添加具有相同用户名的用户。 但确实如此。

从shell:

from app import db
from app.models import User

user = User(username='test')
user2 = User(username='test')

db.session.add(user)
db.session.commit()

db.session.add(user2)
db.session.commit()

User.query.all()

输出:

[<User 'test'>, <User 'test'>]

我错过了什么吗?

您是否在第一次创建表后添加了unique = True 如果是这样,则约束将不会应用于数据库。 您需要如何处理此问题如下:

  1. 使用Flask迁移。 这是非常有用的,允许您迁移现有的数据库模型。 (推荐的)

  2. 如果这是一个测试/ dev环境,只需删除表并再次运行db.create_all()。

我无法通过在创建表之前添加唯一约束来创建数据库来复制您发布的错误。

但是,通过在创建表后添加唯一约束,我能够做到这一点。

希望这可以帮助!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM