Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

ImportError: cannot import name '_ColumnEntity' from 'sqlalchemy.orm.query'

After installing apache-superset using pip in virtual environment, I run:

superset upgrade db   

I run into the following error:

ImportError: cannot import name '_ColumnEntity' from 'sqlalchemy.orm.query' (/Users/ahmedawny/supersetenv/lib/python3.7/site-packages/sqlalchemy/orm/query.py)

Any advice would be appreciated.

like image 979
3awny Avatar asked Mar 15 '21 20:03

3awny


4 Answers

The core reason for this is that sqlalchemy 1.4 shipped, so it is now the default that pip installs. There were many interface changes and a new query interface added.

So upgrading to 1.4 breaks stuff that depends on the sqlalchemy 1.3 API internals. In your requirements.txt file-- pin the project version to the 1.3.x series until the rest of your stuff catches up. For example, as of this date sqlalchemy-utils is still dependent on sqlalchemy 1.3x.

requirements.txt:

sqlalchemy < 1.4.0

Then use:

pip -r requirements.txt

to "downgrade" to the pinned version.

like image 109
InsertSpywareTrackingHere Avatar answered Oct 17 '22 02:10

InsertSpywareTrackingHere


Go to sqlalchemy_utils.functions file and change :

  • from sqlalchemy.orm.query import _ColumnEntity (comment this one, or delete it)
  • from sqlalchemy.orm.context import _ColumnEntity (include)

in consequence of this, i belive it should change some stuff along the code...

like image 32
Raquel Calmon Avatar answered Oct 17 '22 01:10

Raquel Calmon


If you don't want to modify the requirements file, as recommended in @InsertSpywareTrackingHere's answer, you can manually pip install an older version instead:

pip install sqlalchemy==1.3.24
like image 3
Eugene Avatar answered Oct 17 '22 01:10

Eugene


you can temporarily fix this by changing the imports in sqlalchemy_utils\functions\orm.py:

from sqlalchemy.orm.query import _ColumnEntity

to

from sqlalchemy.orm.context import _ColumnEntity
like image 1
Firdous bhat Avatar answered Oct 17 '22 01:10

Firdous bhat