У меня есть несколько баз данных в postgres и mysql.Я хотел бы, чтобы пользователь подключился к базе данных, предоставив учетные данные, а затем отобразил метаданные таблиц (в виде таблиц) в HTML-файле, который он просматривает.
Это соответствующий код.
meta = MetaData()
meta.reflect(bind=eng)
return str(meta.tables)
Возвращает следующее типа <class 'sqlalchemy.util._collections.immutabledict'>
immutabledict({'categories': Table('categories', MetaData(bind=None), Column('category', INTEGER(), table=, primary_key=True, nullable=False, server_default=DefaultClause(, for_update=False)), Column('categoryname', VARCHAR(length=50), table=, nullable=False), schema=None), 'inventory': Table('inventory', MetaData(bind=None), Column('prod_id', INTEGER(), table=, primary_key=True, nullable=False), Column('quan_in_stock', INTEGER(), table=, nullable=False), Column('sales', INTEGER(), table=, nullable=False), schema=None), 'products': Table('products', MetaData(bind=None), Column('prod_id', INTEGER(), table=, primary_key=True, nullable=False, server_default=DefaultClause(, for_update=False)), Column('category', INTEGER(), table=, nullable=False), Column('title', VARCHAR(length=50), table=, nullable=False), Column('actor', VARCHAR(length=50), table=, nullable=False), Column('price', NUMERIC(precision=12, scale=2), table=, nullable=False), Column('special', SMALLINT(), table=), Column('common_prod_id', INTEGER(), table=, nullable=False), schema=None), 'reorder': Table('reorder', MetaData(bind=None), Column('prod_id', INTEGER(), table=, nullable=False), Column('date_low', DATE(), table=, nullable=False), Column('quan_low', INTEGER(), table=, nullable=False), Column('date_reordered', DATE(), table=), Column('quan_reordered', INTEGER(), table=), Column('date_expected', DATE(), table=), schema=None), 'cust_hist': Table('cust_hist', MetaData(bind=None), Column('customerid', INTEGER(), ForeignKey('customers.customerid'), table=, nullable=False), Column('orderid', INTEGER(), table=, nullable=False), Column('prod_id', INTEGER(), table=, nullable=False), schema=None), 'customers': Table('customers', MetaData(bind=None), Column('customerid', INTEGER(), table=, primary_key=True, nullable=False, server_default=DefaultClause(, for_update=False)), Column('firstname', VARCHAR(length=50), table=, nullable=False), Column('lastname', VARCHAR(length=50), table=, nullable=False), Column('address1', VARCHAR(length=50), table=, nullable=False), Column('address2', VARCHAR(length=50), table=), Column('city', VARCHAR(length=50), table=, nullable=False), Column('state', VARCHAR(length=50), table=), Column('zip', INTEGER(), table=), Column('country', VARCHAR(length=50), table=, nullable=False), Column('region', SMALLINT(), table=, nullable=False), Column('email', VARCHAR(length=50), table=), Column('phone', VARCHAR(length=50), table=), Column('creditcardtype', INTEGER(), table=, nullable=False), Column('creditcard', VARCHAR(length=50), table=, nullable=False), Column('creditcardexpiration', VARCHAR(length=50), table=, nullable=False), Column('username', VARCHAR(length=50), table=, nullable=False), Column('password', VARCHAR(length=50), table=, nullable=False), Column('age', SMALLINT(), table=), Column('income', INTEGER(), table=), Column('gender', VARCHAR(length=1), table=), schema=None), 'orders': Table('orders', MetaData(bind=None), Column('orderid', INTEGER(), table=, primary_key=True, nullable=False, server_default=DefaultClause(, for_update=False)), Column('orderdate', DATE(), table=, nullable=False), Column('customerid', INTEGER(), ForeignKey('customers.customerid'), table=), Column('netamount', NUMERIC(precision=12, scale=2), table=, nullable=False), Column('tax', NUMERIC(precision=12, scale=2), table=, nullable=False), Column('totalamount', NUMERIC(precision=12, scale=2), table=, nullable=False), schema=None), 'orderlines': Table('orderlines', MetaData(bind=None), Column('orderlineid', INTEGER(), table=, nullable=False), Column('orderid', INTEGER(), ForeignKey('orders.orderid'), table=, nullable=False), Column('prod_id', INTEGER(), table=, nullable=False), Column('quantity', SMALLINT(), table=, nullable=False), Column('orderdate', DATE(), table=, nullable=False), schema=None)})
Я пытался использовать цикл for для этого в шаблоне jinja, но он говорит: sqlalchemy 'table' object is not iterable
Как сделатьЯ получаю метаданные из базы данных для отображения в виде таблиц в html?