<i id='n62OD'><tr id='n62OD'><dt id='n62OD'><q id='n62OD'><span id='n62OD'><b id='n62OD'><form id='n62OD'><ins id='n62OD'></ins><ul id='n62OD'></ul><sub id='n62OD'></sub></form><legend id='n62OD'></legend><bdo id='n62OD'><pre id='n62OD'><center id='n62OD'></center></pre></bdo></b><th id='n62OD'></th></span></q></dt></tr></i><div id='n62OD'><tfoot id='n62OD'></tfoot><dl id='n62OD'><fieldset id='n62OD'></fieldset></dl></div>
  • <legend id='n62OD'><style id='n62OD'><dir id='n62OD'><q id='n62OD'></q></dir></style></legend>
      <bdo id='n62OD'></bdo><ul id='n62OD'></ul>

      <small id='n62OD'></small><noframes id='n62OD'>

      <tfoot id='n62OD'></tfoot>
      1. 如何进行可以查找&Quot;最新&Quot;、最小&Quot;或&Quot;最大&

        How to make graphql query that can find quot;latestquot; or quot;minquot; or quot;maxquot;(如何进行可以查找Quot;最新Quot;、最小Quot;或Quot;最大Quot;的GraphQL查询)
        <legend id='1Dpmy'><style id='1Dpmy'><dir id='1Dpmy'><q id='1Dpmy'></q></dir></style></legend>

        <small id='1Dpmy'></small><noframes id='1Dpmy'>

          • <bdo id='1Dpmy'></bdo><ul id='1Dpmy'></ul>

              <tbody id='1Dpmy'></tbody>
            1. <i id='1Dpmy'><tr id='1Dpmy'><dt id='1Dpmy'><q id='1Dpmy'><span id='1Dpmy'><b id='1Dpmy'><form id='1Dpmy'><ins id='1Dpmy'></ins><ul id='1Dpmy'></ul><sub id='1Dpmy'></sub></form><legend id='1Dpmy'></legend><bdo id='1Dpmy'><pre id='1Dpmy'><center id='1Dpmy'></center></pre></bdo></b><th id='1Dpmy'></th></span></q></dt></tr></i><div id='1Dpmy'><tfoot id='1Dpmy'></tfoot><dl id='1Dpmy'><fieldset id='1Dpmy'></fieldset></dl></div>

                <tfoot id='1Dpmy'></tfoot>
                • 本文介绍了如何进行可以查找&Quot;最新&Quot;、最小&Quot;或&Quot;最大&Quot;的GraphQL查询的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在尝试结合使用GraphQL和python来检索时间范围内的最低和最高温度。

                  温度表有2列:时间戳和值。

                  我的mods.py是:

                  from django.db import models
                  
                  class Temperature(models.Model):
                      timestamp = models.DateTimeField(auto_now=True)
                      value = models.FloatField()
                  
                      def __str__(self):
                          return f"the value:time is {self.value}:{self.timestamp}"
                  

                  ,schema.py为:

                  class Query(graphene.ObjectType):
                      temperature_statistics = graphene.Field(Temperature)
                  
                      def resolve_temperature_statistics(self, info, **kwargs):
                          before = kwargs.get("before")
                          after = kwargs.get("after")
                      
                          return models.Temperature.objects.filter(created_at__gte=after, created_at__lte=before)
                  

                  返回一段时间内的最低和最高温度的查询应该如下所示:

                  query {
                      temperatureStatistics(after: "2020-12-06T12:00:00+00:00", before: "2020-12-07T12:00:00+00:00") {
                          min
                          max
                      }
                  }
                  

                  我不知道如何实现其中的最小和最大部分。

                  由于在GraphQL查询中使用了min和max,因此我不能只从解析器返回min和max,例如,如果查询是这样编写的,

                  query {
                      temperatureMax(after: "2020-12-06T12:00:00+00:00", before: "2020-12-07T12:00:00+00:00")
                  }
                  

                  我必须想办法使GraphQL能够完成这项工作。

                  回应@Ahtisham的评论。以下是我如何实现不带类型的currentTemperature。

                  schema.py

                  import graphene
                  from graphene_django import DjangoObjectType
                  
                  from temperature import models
                  
                  class Temperature(DjangoObjectType):
                      class Meta:
                          model = models.Temperature
                  
                  class Query(graphene.ObjectType):
                      current_temperature = graphene.Field(Temperature)
                  
                      def resolve_current_temperature(self, info, **kwargs):
                          return models.Temperature.objects.last()
                  
                  
                  schema = graphene.Schema(query=Query)
                  

                  mods.py

                  from django.db import models
                  
                  class Temperature(models.Model):
                      timestamp = models.DateTimeField(auto_now=True)
                      value = models.FloatField()
                  
                  

                  这在使用此GraphQL查询进行查询时起作用:

                  query {
                      currentTemperature {
                          timestamp
                          value
                      }
                  }
                  

                  更新2

                  我已经根据@Ahtisham的回答更新了schema.py,现在将其作为我的schema.py:

                  import graphene
                  from graphene_django import DjangoObjectType
                  from django.db.models import Max, Min
                  
                  
                  from temperature import models
                  
                  class Temperature(DjangoObjectType):
                      class Meta:
                          model = models.Temperature
                  
                  class RangeType(graphene.ObjectType):
                      min = graphene.String()
                      max = graphene.String()
                  
                  class Query(graphene.ObjectType):
                      current_temperature = graphene.Field(Temperature, id=graphene.Int())
                      temperature_statistics = graphene.Field(Temperature, before=graphene.String(), after=graphene.String())
                  
                      def resolve_current_temperature(self, info, **kwargs):
                          return models.Temperature.objects.latest('timestamp')
                          
                  
                      def resolve_temperature_statistics(self, info, before=None, after=None):
                          range_type = RangeType()
                  
                          if before and after is not None:
                              range_type.min_ = models.Temperature.objects.filter(created_at__gte=after, created_at__lte=before).aggregate(Min('temperature'))
                              range_type.max_ = models.Temperature.objects.filter(created_at__gte=after, created_at__lte=before).aggregate(Max('temperature'))
                              return range_type
                              
                          elif before is None and after is not None:
                              range_type.min_ = models.Temperature.objects.filter(created_at__gte=after).aggregate(Min('temperature'))
                              range_type.max_ = models.Temperature.objects.filter(created_at__gte=after).aggregate(Max('temperature'))
                              return range_type
                  
                          elif after is None and before is not None:
                              range_type.min_ = models.Temperature.objects.filter(created_at__lte=before).aggregate(Min('temperature'))
                              range_type.max_ = models.Temperature.objects.filter(created_at__lte=before).aggregate(Max('temperature'))
                              return range_type
                  
                          else:
                              range_type.min_ = models.Temperature.objects.aggregate(Min('temperature'))
                              range_type.max_ = models.Temperature.objects.aggregate(Max('temperature'))
                              return range_type
                  
                      
                  schema = graphene.Schema(query=Query)
                  

                  GraphQL显示此错误

                  {
                    "errors": [
                      {
                        "message": "Cannot query field "min_" on type "Temperature".",
                        "locations": [
                          {
                            "line": 3,
                            "column": 7
                          }
                        ]
                      },
                      {
                        "message": "Cannot query field "max_" on type "Temperature".",
                        "locations": [
                          {
                            "line": 4,
                            "column": 7
                          }
                        ]
                      }
                    ]
                  }
                  

                  执行此查询时

                  query {
                      temperatureStatistics {
                                  min
                                  max
                          }
                  }
                  

                  更新3

                  更改后

                      temperature_statistics = graphene.Field(Temperature, before=graphene.String(), after=graphene.String())
                  
                  

                      temperature_statistics = graphene.Field(RangeType, before=graphene.String(), after=graphene.String())
                  
                  

                  GraphQL现在显示此错误

                  {
                    "errors": [
                      {
                        "message": "Cannot resolve keyword 'temperature' into field. Choices are: id, timestamp, value",
                        "locations": [
                          {
                            "line": 2,
                            "column": 5
                          }
                        ],
                        "path": [
                          "temperatureStatistics"
                        ]
                      }
                    ],
                    "data": {
                      "temperatureStatistics": null
                    }
                  }
                  

                  执行此查询时

                  query {
                      temperatureStatistics {
                                  min
                                  max
                          }
                  }
                  

                  同时:

                  GraphQL显示此错误

                  {
                    "errors": [
                      {
                        "message": "Cannot resolve keyword 'created_at' into field. Choices are: id, timestamp, value",
                        "locations": [
                          {
                            "line": 2,
                            "column": 5
                          }
                        ],
                        "path": [
                          "temperatureStatistics"
                        ]
                      }
                    ],
                    "data": {
                      "temperatureStatistics": null
                    }
                  }
                  

                  执行此查询时

                  query {
                      temperatureStatistics(after: "2020-12-06T12:00:00+00:00", before: "2020-12-07T12:00:00+00:00")) {
                                  min
                                  max
                          }
                  }
                  

                  更新4

                  最后一个错误是因为我在Django查询中使用了‘温度’而不是‘值’。现在可以使用了。

                  推荐答案

                  您可以使用MIN和MAX定义一个新类型,然后将其添加到查询中,如下所示:

                  class RangeType(graphene.ObjectType):
                      min = graphene.String()
                      max = graphene.String()
                         
                  
                  class Query(graphene.ObjectType):
                      temperature_statistics = graphene.Field(
                         RangeType, before=graphene.String(), after=graphene.String()
                      )
                  
                      def resolve_temperature_statistics(self, info, before=None, after=None):
                          range_type = RangeType()
                          range_type.min = # query to get min value
                          range_type.max = # query to get max value
                          return range_type
                  

                  调用查询应该相同。

                  这篇关于如何进行可以查找&Quot;最新&Quot;、最小&Quot;或&Quot;最大&Quot;的GraphQL查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  GUI Freezes while downloading PyQt5 and Pytube(GUI在下载PyQt5和Pytube时冻结)
                  How to solve memory issues while multiprocessing using Pool.map()?(如何解决使用Pool.map()进行多处理时的内存问题?)
                  Python - How to use FastAPI and uvicorn.run without blocking the thread?(Python-如何使用FastAPI和uvicorn.run而不阻塞线程?)
                  How to increment a shared counter from multiple processes?(如何从多个进程递增共享计数器?)
                  Using pika, how to connect to rabbitmq running in docker, started with docker-compose with external network?(使用pika,如何连接运行在docker中的rabbitmq,从docker开始-与外部网络连接?)
                  How to use .rolling() on each row of a Pandas dataframe?(如何对 pandas 数据帧的每一行使用.roll()?)

                      <legend id='W4LOG'><style id='W4LOG'><dir id='W4LOG'><q id='W4LOG'></q></dir></style></legend>

                      • <bdo id='W4LOG'></bdo><ul id='W4LOG'></ul>

                        <small id='W4LOG'></small><noframes id='W4LOG'>

                          <tbody id='W4LOG'></tbody>

                            <tfoot id='W4LOG'></tfoot>
                          1. <i id='W4LOG'><tr id='W4LOG'><dt id='W4LOG'><q id='W4LOG'><span id='W4LOG'><b id='W4LOG'><form id='W4LOG'><ins id='W4LOG'></ins><ul id='W4LOG'></ul><sub id='W4LOG'></sub></form><legend id='W4LOG'></legend><bdo id='W4LOG'><pre id='W4LOG'><center id='W4LOG'></center></pre></bdo></b><th id='W4LOG'></th></span></q></dt></tr></i><div id='W4LOG'><tfoot id='W4LOG'></tfoot><dl id='W4LOG'><fieldset id='W4LOG'></fieldset></dl></div>