In the application that I'm building, I've used a Composite Type of Custom types to store data. It's basically a list of simple objects of type:
bin = CompositeType(columns=[Column('label', String()), Column('head', Float()), Column('tail', Float())], name='bin')
This is built into my class in a way such as:
class Myclass(db.Model):
   id = sa.Column('id', sa.Integer(), nullable=False)
   bin = sa.Column('bin', CompositeArray(CompositeType('bin', [Column('label', String()), Column('head', Float()), Column('tail', Float())])))
Then I try:
   id = '111331'
   bins ={'1':{'start':0,'end':1},'2':{'start':1,'end':2}}
   myclass = Myclass(id = int(id), bins = [(bin_key, bins[bin_key]['start'], bins[bin_key]['end']) for bin_key in bins])
   # The object creation works flawlessly.
   db.session.add(myclass)
   db.session.commit()
   # Error happens in SQLAlchemy commit
Suddenly, I'm getting this error:
sqlalchemy.exc.ProgrammingError: (psycopg2.errors.DatatypeMismatch)
column "bin" is of type bin[] but expression is of type record[] (...)
^ HINT:  You will need to rewrite or cast the expression.
But I can't manage to find how to do this casting.
Should I make a class to describe this type used in postgres and then instantiate it in the list comprehension? If so, please, give examples.
Btw, this used to work. Stopped working when I migrated using flask db migrate. However, database structure is exactly the same.
 
                        
I had the same problem once. First of all I can recommend to update
Flask,Flask-SQLAlchemyand related packages.Flask==1.1.2,Flask-SQLAlchemy==2.4.0,SQLAlchemy==1.3.18,SQLAlchemy-Utils==0.36.6works fine:But a few years ago I solved the problem using sqlalchemy_utils.register_composites(). It was something like this:
Also you can try psycopg2.extras.register_composite.