向 Django QuerySet 添加值
Adding values to Django QuerySet
有什么方法可以将非 Django 提供的值附加到查询中吗?
例如,要查明一家商店是否关门,我可以 运行 一个名为 get_closed_stores()
的函数,其中 return 是一个关门商店的列表。
商店关门
[00090, 00240, 00306, 00438, 03005, 05524]
太好了,现在我们有了关门商店的商店编号。让我们获取那些实际的商店对象。
查询
Store.objects.filter(
store_number__in=[00090, 00240, 00306, 00438, 03005, 05524]
)
我们现在有了 QuerySet,但我们绝对无法检测商店何时关闭,因为数据库不包含任何有关紧急关闭的信息,但 Sharepoint 包含。所以回到 get_closed_stores()
我们可以 return 关闭日期 以及商店编号所以我们的 关闭的商店列表(字典)看起来更像下面这样:
带日期的商店列表
{
[00090, '1/28/19 5:00PM'],
[00240,'1/28/19 5:00PM'],
[00306, '1/28/19 5:00PM'],
[00438,'1/28/19 5:00PM'],
[03005,'1/28/19 5:00PM'],
[05524, '1/28/19 5:00PM']
}
既然日期与我的商店编号有关,我可以将其添加到我的查询集中(理想情况下)并从我的前端访问它。
因此,如果我正在处理与 Django ORM 相关的任何事情,annotate()
将是理想的选择,但是当涉及到 "injecting" 外部数据时,我在寻找什么?
我绝对可以在我的前端从 JS 调用每个商店,但如果我能绕过它,我宁愿不这样做
A QuerySet 本身并没有什么神奇或特殊的东西,最后它仍然是一个字典,所以我有随机以我通常的方式附加到字典的想法,并且它奏效了。
我的函数现在返回字典:
{ "store_number": "close_date" }
我的观点采用这本字典并使用键(商店编号)查询数据库,然后通过简单地说:
将商店的关闭日期附加为 store.close_date
store.close_date = store_list[store_number]
这可能会改变,但我想让它接近原始问题,以便未来的读者可以阅读。以下是我的看法。
@login_required
def store_closures(request):
store_list = get_closed_stores()
store_nums = store_list.keys()
closed_stores = Store.objects.filter(store_number__in=store_nums)
for store in closed_stores:
store.close_date = store_list["{:05d}".format(store.store_number)]
return render(request, 'all_store_closures.html', {'closed_stores':closed_stores})
因此,如果您想将非 Django 值添加到查询集中,您可以使用附加到字典的标准方法。
for obj in query:
obj.desired_name = 'desired_value'
当然可以使用模板中的 {{ object.desired_name }}
进行访问。
有什么方法可以将非 Django 提供的值附加到查询中吗?
例如,要查明一家商店是否关门,我可以 运行 一个名为 get_closed_stores()
的函数,其中 return 是一个关门商店的列表。
商店关门
[00090, 00240, 00306, 00438, 03005, 05524]
太好了,现在我们有了关门商店的商店编号。让我们获取那些实际的商店对象。
查询
Store.objects.filter(
store_number__in=[00090, 00240, 00306, 00438, 03005, 05524]
)
我们现在有了 QuerySet,但我们绝对无法检测商店何时关闭,因为数据库不包含任何有关紧急关闭的信息,但 Sharepoint 包含。所以回到 get_closed_stores()
我们可以 return 关闭日期 以及商店编号所以我们的 关闭的商店列表(字典)看起来更像下面这样:
带日期的商店列表
{
[00090, '1/28/19 5:00PM'],
[00240,'1/28/19 5:00PM'],
[00306, '1/28/19 5:00PM'],
[00438,'1/28/19 5:00PM'],
[03005,'1/28/19 5:00PM'],
[05524, '1/28/19 5:00PM']
}
既然日期与我的商店编号有关,我可以将其添加到我的查询集中(理想情况下)并从我的前端访问它。
因此,如果我正在处理与 Django ORM 相关的任何事情,annotate()
将是理想的选择,但是当涉及到 "injecting" 外部数据时,我在寻找什么?
我绝对可以在我的前端从 JS 调用每个商店,但如果我能绕过它,我宁愿不这样做
A QuerySet 本身并没有什么神奇或特殊的东西,最后它仍然是一个字典,所以我有随机以我通常的方式附加到字典的想法,并且它奏效了。
我的函数现在返回字典:
{ "store_number": "close_date" }
我的观点采用这本字典并使用键(商店编号)查询数据库,然后通过简单地说:
将商店的关闭日期附加为store.close_date
store.close_date = store_list[store_number]
这可能会改变,但我想让它接近原始问题,以便未来的读者可以阅读。以下是我的看法。
@login_required
def store_closures(request):
store_list = get_closed_stores()
store_nums = store_list.keys()
closed_stores = Store.objects.filter(store_number__in=store_nums)
for store in closed_stores:
store.close_date = store_list["{:05d}".format(store.store_number)]
return render(request, 'all_store_closures.html', {'closed_stores':closed_stores})
因此,如果您想将非 Django 值添加到查询集中,您可以使用附加到字典的标准方法。
for obj in query:
obj.desired_name = 'desired_value'
当然可以使用模板中的 {{ object.desired_name }}
进行访问。