如何使用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:zgghyys123@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=, 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']

# 准确的获取字段名的话,可以这样。
# 这获取的就是数据库里面真实的字段名称
print(inspect(ow).c.keys())  # ['id', 'name', 'age', 'hp', 'attack', 'role', 'ultimate', 'country']

转载于:https://www.cnblogs.com/traditional/p/11505189.html

你可能感兴趣的:(如何使用sqlalchemy获取表的主键、以及每一个字段名)