如何获取 SQLAlchemy 对象的主键的名称? [英] How do I get the name of an SQLAlchemy object's primary key?

查看:22
本文介绍了如何获取 SQLAlchemy 对象的主键的名称?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我只想以编程方式确定 SQLalchemy 模型的主键的名称.

解决方案

如果使用 SQLAlchemy 0.8 或更高版本,您应该使用 运行时检查 API.

如果模型类是User,唯一的主键是id

<预><代码>>>>从 sqlalchemy.inspection 导入检查>>>检查(用户).primary_key[0].name'身份证'

如果模型类是User并且有很多主键,

<预><代码>>>>从 sqlalchemy.inspection 导入检查>>>[key.name for key in inspect(User).primary_key]['id', '姓名']

如果使用低于 0.8 的 SQLAlchemy 版本,则应改用 class_mapper() 函数.

<预><代码>>>>从 sqlalchemy.orm 导入 class_mapper>>>class_mapper(User).primary_key[0].name'身份证'

在这种情况下,inspect() 函数和 class_mapper() 函数返回相同的对象,但使用 inspect() 是更具前瞻性.

I just want to programatically determine the name of an SQLalchemy model's primary key.

解决方案

If using SQLAlchemy version 0.8 or later, you should use the runtime inspection API.

If the model class is User and the sole primary key is id,

>>> from sqlalchemy.inspection import inspect
>>> inspect(User).primary_key[0].name
'id'

If the model class is User and there are many primary keys,

>>> from sqlalchemy.inspection import inspect
>>> [key.name for key in inspect(User).primary_key]
['id', 'name']

If using SQLAlchemy version less than 0.8, you should use the class_mapper() function instead.

>>> from sqlalchemy.orm import class_mapper
>>> class_mapper(User).primary_key[0].name
'id'

In this case, the inspect() function and the class_mapper() function return the same object, but using inspect() is more future-proof.

这篇关于如何获取 SQLAlchemy 对象的主键的名称?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆