0

When I run

python manage.py inspectdb --database=sybase_database

it ends with error message:

Database.register_converter(Database.DT_DECIMAL, util.typecast_decimal) AttributeError: module 'django.db.backends.utils' has no attribute 'typecast_decimal'

$ pip freeze
certifi==2021.10.8
chardet==3.0.4
defusedxml==0.7.1
Django==2.2.4
django-allauth==0.40.0
django-bootstrap-form==3.4
django-bootstrap3==15.0.0
django-crispy-forms==1.7.2
django-crudbuilder==0.2.7
django-debug-toolbar==1.10.1
django-filter==2.2.0
django-mssql-backend==2.8.1
django-tables2==2.4.1
idna==2.8
importlib-metadata==2.1.1
oauthlib==3.1.1
pyodbc==4.0.32
python-dateutil==2.8.2
python3-openid==3.2.0
pytz==2021.3
requests==2.21.0
requests-oauthlib==1.3.0
six==1.16.0
sqlany-django==1.13
sqlanydb==1.0.11
sqlparse==0.4.2
urllib3==1.24.3
zipp==3.6.0

Ubuntu 18.04

xralf
  • 3,312
  • 45
  • 129
  • 200

2 Answers2

1

Replaced typecast_decimal() with decimal.Decimal()

change base.py code like to

Database.register_converter("decimal", decoder(decimal.Decimal))

and in utils.py you can return

decimal.Decimal()

maybe help to you

1

sqlany-django only supports up to Django 1.8.5 (Django 1.7.0 for inspectdb command).
It is no longer maintained; it was last updated in May 2016.

You can patch for later versions of Django in manage.py or an AppConfig.

# Django >= 2.0, for sqlany_django/base.py
import decimal
from django.db.backends import utils
utils.typecast_decimal = decimal.Decimal

# Django >= 1.11, for BaseDatabaseWrapper
from sqlany_django.base import DatabaseWrapper
DatabaseWrapper.client_class = lambda self, connection: None
DatabaseWrapper.creation_class = lambda self, connection: None
DatabaseWrapper.features_class = lambda self, connection: None
DatabaseWrapper.introspection_class = lambda self, connection: None
DatabaseWrapper.ops_class = lambda self, connection: None

# Django >= 1.7.1, for inspectdb
from django.db.backends import utils
from sqlany_django import base
class CursorWrapper(base.CursorWrapper, utils.CursorWrapper):
    pass
base.CursorWrapper = CursorWrapper

References:


Stack traces:

  1. Regarding DatabaseWrapper
Traceback (most recent call last):
  ...
  File "/path/to/site-packages/django/core/management/commands/inspectdb.py", line 40, in handle_inspection
    connection = connections[options['database']]
  File "/path/to/site-packages/django/db/utils.py", line 207, in __getitem__
    conn = backend.DatabaseWrapper(db, alias)
  File "/path/to/site-packages/sqlany_django/base.py", line 447, in __init__
    super(DatabaseWrapper, self).__init__(*args, **kwargs)
  File "/path/to/site-packages/django/db/backends/base/base.py", line 102, in __init__
    self.client = self.client_class(self)
TypeError: 'NoneType' object is not callable
  1. Regarding CursorWrapper
Traceback (most recent call last):
  ...
  File "/path/to/site-packages/django/core/management/commands/inspectdb.py", line 47, in handle_inspection
    with connection.cursor() as cursor:
AttributeError: __enter__
aaron
  • 39,695
  • 6
  • 46
  • 102
  • Thanks, I will try it on monday. But I think I can accept it, Django 1.8 solved it, but I have to find out, how to run two Django projects on one IP address. Don't you possibly know some link where is it described or should I rather ask another question? – xralf Jan 22 '22 at 17:39
  • I don't know about that. – aaron Jan 22 '22 at 18:15
  • Did you get this to work with Django 2.2.4? – aaron Jan 28 '22 at 11:09
  • I tried it now and it's better. Now there is an error `Unable to inspect table 'xxx' # The error was: subclasses of BaseDatabaseIntrospection may require a get_constraints() method ` – xralf Jan 28 '22 at 11:42
  • Can you share the stack trace? (Or do you use TeamVIewer? I don't have a Sybase DB to test with.) – aaron Jan 28 '22 at 12:09