django 中如何将两个查询集合并

在我们项目中,由于各种原因或者分表后,我们需要查询两个表然后将其合并并排序来序列化返回给前端,那么我们合并查询集:
代码:

# -*- coding: utf-8 -*-
# !/usr/bin/python3
import os, datetime, time, random,base64, json
import sys
import oss2

BASE_DIR = os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))

sys.path.append(os.path.join(BASE_DIR, 'qianhe'))
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "qianhe.settings.settings")
import django

django.setup()
from itertools import chain
from django.db.models import F, Q, Sum
from task.models import Task, ChannelTask, TaskArea, ExtendTask, BigExtendTask, TaskOrderMiddleware, TaskOrder, AuthorizerInfo, ApplyPutTask, TaskOrderFirst


def update_data():
    """
    更新数据
    """

    query1 = TaskOrder.objects.all()
    query2 = TaskOrderFirst.objects.all()
    print(query1)
    print(query2)
    quer = list(chain(query1, query2))  # 不排序
    print(quer)

    sort_quer = sorted(chain(query1, query2), key=lambda instance: instance.create_time)  # 排序
    print(sort_quer)


if __name__ == '__main__':
    update_data()
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值