我正在寻找一种仅 SQLAlchemy 的解决方案,用于将从表单提交收到的字典转换为数据库中的一系列行,每个行对应提交的每个字段。这是为了处理不同应用程序之间差异很大的首选项和设置。但是,它很可能适用于创建类似数据透视表的功能。我在 ETL 工具中看到过这种类型的事情,但我一直在寻找一种直接在 ORM 中执行此操作的方法。我找不到任何有关它的文档,但也许我错过了一些东西。
Example:
从表单提交:{"UniqueId":1, "a":23, "b":"Hello", "c":"World"}
我希望对其进行转换(在 ORM 中),以便将其记录在数据库中,如下所示:
_______________________________________
|UniqueId| ItemName | ItemValue |
---------------------------------------
| 1 | a | 23 |
---------------------------------------
| 1 | b | Hello |
---------------------------------------
| 1 | c | World |
---------------------------------------
选择后,结果将(在 ORM 中)转换回每个单独值的一行数据。
---------------------------------------------------
| UniqueId | a | b | c |
---------------------------------------------------
| 1 | 23 | Hello | World |
---------------------------------------------------
我假设更新时最好的做法是将删除/创建包装在事务中,以便删除当前记录并插入新记录。
ItemNames 的最终列表将保存在单独的表中。
完全开放于更优雅的解决方案,但如果可能的话,希望远离数据库端。
我正在使用 SQLAlchemy 的 declarative_base 方法。
提前致谢...
Cheers,
Paul