如何使用sqlalchemy获取表的主键以及每一个字段名

Posted traditional

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何使用sqlalchemy获取表的主键以及每一个字段名相关的知识,希望对你有一定的参考价值。

使用sqlalchemy获取到的结果只包含数据,不包含字段,那么我们如何获取到对应字段呢?以及如何获取某张表的主键呢?

from sqlalchemy.ext.automap import automap_base
from sqlalchemy.orm import sessionmaker
from sqlalchemy import MetaData, inspect, create_engine

engine = create_engine("postgresql://postgres:******@localhost:5432/postgres")
session = sessionmaker(bind=engine)()

# 将数据库的表反射出来
metadata = MetaData(bind=engine)
metadata.reflect(bind=engine, schema="anime", only=["overwatch"])
Base = automap_base(metadata=metadata)
Base.prepare()

# ow就是overwatch表对应的内
ow = getattr(Base.classes, "overwatch")

# 获取主键
primary_key = inspect(ow).primary_key

print(primary_key)  # (Column('id', INTEGER(), table=<overwatch>, primary_key=True, nullable=False),)
# 由于会有多个主键,所以是一个序列。这里我们只有一个主键,所以取第一个,然后拿到名字
print(primary_key[0].name)  # id


# 如何获取字段名呢?
res = session.query(ow).selectable.columns
print(res)
"""
['anime_overwatch_id', 'anime_overwatch_name', 'anime_overwatch_age', 
'anime_overwatch_hp', 'anime_overwatch_attack', 'anime_overwatch_role', 
'anime_overwatch_ultimate', 'anime_overwatch_country']
"""
# 可以看到,会自动将schema、table_name、column用_进行拼接,准确的说这不是字段名,而是在查询字段的时候起的别名
# 对于单表来说,也可以得出字段名,直接以最后一个下划线进行分割,然后取最后一个元素即可
# 记得要转化成str类型
print([str(r).rsplit("_")[-1] for r in res])  # ['id', 'name', 'age', 'hp', 'attack', 'role', 'ultimate', 'country']

以上是关于如何使用sqlalchemy获取表的主键以及每一个字段名的主要内容,如果未能解决你的问题,请参考以下文章

Oracle 获取表的主键外键以及唯一约束条件

如何使用 EFCore 获取一个表的主键计数到另一个表

如何获取 JDBC 中所有表的主键?

如何在 C# 中获取 Ms Access 表的主键

oracle 如何获取表的主键列名,如何获取表的所有列名

如何在 C# 中获取 DataGridView 中的主键?