我可以将 django orm 的列作为字符串 + 变量访问吗?

Can I going to access django orm's column as a string + variable?

我可以将 django orm 的列作为字符串 + 变量访问吗?

例如可能吗?

    for x in range(i, 98)
        CategoryNick.obejcts.filter(author=request.user).update("ca"+(x+1)=F('ca'+x))

或者有其他方法吗?

感谢让我知道

可以用字典传,然后字典解包。事实上,我们可以通过以下方式批量更新:

data = {'ca{}'.format(x+1): F('ca{}'.format(x)) for x in range(i, 98)}
CategoryNick.objects.filter(
    author=request.user
).update(<b>**data</b>)

因此,我们将执行单个更新查询,如下所示:

UPDATE app_categorynick
SET ca2 = ca1, ca3 = ca2, ca4 = ca3, …, ca98 = ca97

注意前面的两个星号 (**)。如果你用 some_dict 调用函数 f(**some_dict),例如 some_dict = {'a': 4, 'b': 2},它会用 f(a=4, b=2).

调用 f

话虽这么说。通常,如果您在模型中存储了任意数量的值,那么使用大量列来执行此操作并不是一个好主意。因为您永远不知道需要额外的列。通常会制作一个额外的模型,并定义从该模型到目标模型的多对一关系。