sqlalchemy_utils char(32) UUIDType не найден

Я использую UUIDType библиотеки http://sqlalchemy-utils.readthedocs.io/en/latest/data_types.html, чтобы мои модели использовали поле типа UUID для PostgreSQL.

Я следую инструкциям на документах, и после установки они добавляются в модели соответственно в соответствии со спецификациями документов:

Модель MISC:

...
from sqlalchemy_utils import UUIDType, force_auto_coercion
...

force_auto_coercion()

class Misc(db.Model):
    __tablename__ = 'misc'

    id = db.Column(db.Integer, primary_key=True)
    key = db.Column(db.String(), index=True)
    user_id = db.Column(UUIDType(binary=False), db.ForeignKey('user.id'))
...

ПАСПОРТ Модель:

...
from sqlalchemy_utils import UUIDType, force_auto_coercion
...

force_auto_coercion()

class Passport(db.Model):
    __tablename__ = 'passport'

    id = db.Column(db.Integer, primary_key=True)
    public = db.Column(db.Boolean())
    status = db.Column(db.Integer, default=1)
    terms_accepted = db.Column(db.Boolean(), default=False)
    completition_level = db.Column(db.String())
    user_id = db.Column(UUIDType(binary=False), db.ForeignKey('user.id'))
...

ПОЛЬЗОВАТЕЛЬ Модель:

...
from sqlalchemy_utils import UUIDType, force_auto_coercion
...

force_auto_coercion()

class User(db.Model):
    __tablename__ = 'user'

    id = db.Column(UUIDType(binary=False), primary_key=True)

Но когда я пытаюсь запустить свой python manage.py migrate Команда выдает следующую ошибку (завершите трассировку ниже):

    Traceback (most recent call last):
  File "manage.py", line 4, in <module>
    from seed import createdata, dropdb, dropdata
  File "C:\www\liu-passport-api\seed.py", line 11, in <module>
    from flask_application import app, db
  File "C:\www\liu-passport-api\flask_application\__init__.py", line 52, in <module>
    import flask_application.controllers
  File "C:\www\liu-passport-api\flask_application\controllers\__init__.py", line 1, in <module>
    from . import information, files_manager, user
  File "C:\www\liu-passport-api\flask_application\controllers\user\__init__.py", line 1, in <module>
    from .user import UserApi
  File "C:\www\liu-passport-api\flask_application\controllers\user\user.py", line 20, in <module>
    class UserBodyApi(Resource):
  File "C:\www\liu-passport-api\flask_application\controllers\user\user.py", line 24, in UserBodyApi
    @swagger.doc(get_user_doc(User))
  File "C:\www\liu-passport-api\flask_application\controllers\user\user_doc.py", line 18, in get_user_doc
    'schema': factory(UserSchema),
  File "C:\www\liu-passport-api\env\lib\site-packages\alchemyjsonschema\__init__.py", line 318, in __call__
    schema["properties"] = self._build_properties(walker, schema, overrides=overrides, depth=depth)
  File "C:\www\liu-passport-api\env\lib\site-packages\alchemyjsonschema\__init__.py", line 379, in _build_properties
    itype, sub["type"] = self.classifier[c.type]
  File "C:\www\liu-passport-api\env\lib\site-packages\alchemyjsonschema\__init__.py", line 105, in __getitem__
    raise InvalidStatus("notfound: {k}. (cls={cls})".format(k=k, cls=cls))
alchemyjsonschema.InvalidStatus: notfound: CHAR(32). (cls=<class 'sqlalchemy_utils.types.uuid.UUIDType'>)

Я делаю что-то неправильно?

0 ответов

Другие вопросы по тегам