GraphQL Spring Boot Client:处理对象列表的查询

graphql spring boot client:处理对象列表的查询

本文档旨在指导开发者如何在 Spring Boot GraphQL 客户端中传递对象列表进行查询。我们将探讨如何构建 GraphQL 查询,并使用 `GraphQLTemplate` 发送包含对象列表的请求。通过本文,你将学会如何有效地与 GraphQL 服务交互,并获取所需的数据。

在使用 Spring Boot 构建 GraphQL 客户端时,一个常见的需求是向 GraphQL 服务传递一个对象列表作为查询参数。这在需要根据多个 ID 或其他属性检索数据时非常有用。以下是如何使用 GraphQLTemplate 实现此功能的详细步骤。

1. 定义 GraphQL Schema (服务端)

首先,确保你的 GraphQL 服务端定义了正确的 schema,允许接收对象列表作为参数。例如,如果你的服务端有一个 Person 类型,并且你想通过 ID 列表查询多个 Person 对象,你的 schema 可能如下所示:

type Person {  firstName: String  middleName: String  lastName: String  birthDt: String}type Query {  getPersonsByIds(personIds: [ID!]): [Person]}

这里的 getPersonsByIds 查询接受一个 personIds 参数,它是一个 ID 类型的非空列表,并返回一个 Person 对象的列表。

2. 构建 GraphQL 查询 (客户端)

在 Spring Boot 客户端,你需要构建一个 GraphQL 查询,其中包含一个变量,该变量将绑定到你的对象列表。例如:

query GetPersonsByIds($personIds: [BigInteger]) {  getPersonsByIds(personIds: $personIds) {    firstName    middleName    lastName    birthDt  }}

注意 $personIds: [BigInteger] 部分,它定义了一个名为 personIds 的变量,该变量的类型是 BigInteger 的列表。 确保服务端声明的ID类型与客户端保持一致,例如服务端ID是String,客户端也需要声明为String。

3. 使用 GraphQLTemplate 发送请求

表单大师AI 表单大师AI

一款基于自然语言处理技术的智能在线表单创建工具,可以帮助用户快速、高效地生成各类专业表单。

表单大师AI 74 查看详情 表单大师AI

现在,你可以使用 GraphQLTemplate 发送包含对象列表的请求。以下是一个示例:

import com.github.americanexpress.graphql.spring.GraphQLTemplate;import com.github.americanexpress.graphql.spring.GraphQLRequestEntity;import org.springframework.stereotype.Service;import java.net.MalformedURLException;import java.util.Arrays;import java.util.List;import java.math.BigInteger;@Servicepublic class PersonService {    private final GraphQLTemplate graphQLTemplate = new GraphQLTemplate();    private final String url = "http://localhost:8084/graphql";    public List getPersonsByIds(List personIds) {        GraphQLRequestEntity requestEntity;        try {            requestEntity = GraphQLRequestEntity.Builder()                .url(url)                .requestMethod(GraphQLTemplate.GraphQLMethod.QUERY)                .request("query GetPersonsByIds($personIds: [BigInteger]) {n" +                    "  getPersonsByIds(personIds: $personIds) {n" +                    "    firstNamen" +                    "    middleNamen" +                    "    lastNamen" +                    "    birthDtn" +                    "  }n" +                    "}"                )                .variables(new Variable("personIds", personIds)) // 传递 personIds 列表                .build();        } catch (MalformedURLException e) {            throw new RuntimeException(e);        }        return graphQLTemplate.query(requestEntity, ResponseGetPersonsByIds.class).getResponse().getGetPersonsByIds();    }    public static class Variable {        private final String key;        private final T value;        public Variable(String key, T value) {            this.key = key;            this.value = value;        }        public String getKey() {            return key;        }        public T getValue() {            return value;        }    }    // 假设的 ResponseGetPersonsByIds 类    public static class ResponseGetPersonsByIds {        private GetPersonsByIdsResponse response;        public GetPersonsByIdsResponse getResponse() {            return response;        }        public void setResponse(GetPersonsByIdsResponse response) {            this.response = response;        }    }    public static class GetPersonsByIdsResponse {        private List getPersonsByIds;        public List getGetPersonsByIds() {            return getPersonsByIds;        }        public void setGetPersonsByIds(List getPersonsByIds) {            this.getPersonsByIds = getPersonsByIds;        }    }    public static class Person {        private String firstName;        private String middleName;        private String lastName;        private String birthDt;        // Getters and setters        public String getFirstName() {            return firstName;        }        public void setFirstName(String firstName) {            this.firstName = firstName;        }        public String getMiddleName() {            return middleName;        }        public void setMiddleName(String middleName) {            this.middleName = middleName;        }        public String getLastName() {            return lastName;        }        public void setLastName(String lastName) {            this.lastName = lastName;        }        public String getBirthDt() {            return birthDt;        }        public void setBirthDt(String birthDt) {            this.birthDt = birthDt;        }    }    public static void main(String[] args) {        PersonService personService = new PersonService();        List ids = Arrays.asList(new BigInteger("2477142261427744786"), new BigInteger("2477142261427744787"));        List persons = personService.getPersonsByIds(ids);        if (persons != null) {            persons.forEach(person -> System.out.println(person.getFirstName()));        } else {            System.out.println("No persons found.");        }    }}

在这个例子中,personIds 是一个 BigInteger 类型的列表,它作为 variables 参数传递给 GraphQLRequestEntity.Builder()。

4. 处理响应

graphQLTemplate.query() 方法返回一个包含响应数据的对象。你需要定义相应的 Java 类来映射 GraphQL 响应。在上面的例子中,ResponseGetPersonsByIds 类用于封装响应数据。

注意事项:

确保 GraphQLTemplate 依赖已正确添加到你的项目中。服务端和客户端的变量类型必须匹配。处理可能出现的异常,例如网络错误或 GraphQL 服务端返回的错误。根据你的实际需求调整 GraphQL 查询和 Java 类。

总结:

通过使用 GraphQLTemplate 和正确构建 GraphQL 查询,你可以轻松地将对象列表作为参数传递给 Spring Boot GraphQL 客户端中的查询。 重要的是要确保服务端和客户端之间的类型匹配,并正确处理响应数据。 这种方法可以有效地检索与多个 ID 或其他属性相关的数据。

以上就是GraphQL Spring Boot Client:处理对象列表的查询的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/299535.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 00:17:23
下一篇 2025年11月5日 00:18:29

相关推荐

  • 怎样用免费工具美化PPT_免费美化PPT的实用方法分享

    利用KIMI智能助手可免费将PPT美化为科技感风格,但需核对文字准确性;2. 天工AI擅长优化内容结构,提升逻辑性,适合高质量内容需求;3. SlidesAI支持语音输入与自动排版,操作便捷,利于紧急场景;4. Prezo提供多种模板,自动生成图文并茂幻灯片,适合学生与初创团队。 如果您有一份内容完…

    2025年12月6日 软件教程
    000
  • Pages怎么协作编辑同一文档 Pages多人实时协作的流程

    首先启用Pages共享功能,点击右上角共享按钮并选择“添加协作者”,设置为可编辑并生成链接;接着复制链接通过邮件或社交软件发送给成员,确保其使用Apple ID登录iCloud后即可加入编辑;也可直接在共享菜单中输入邮箱地址定向邀请,设定编辑权限后发送;最后在共享面板中管理协作者权限,查看实时在线状…

    2025年12月6日 软件教程
    100
  • REDMI K90系列正式发布,售价2599元起!

    10月23日,redmi k90系列正式亮相,推出redmi k90与redmi k90 pro max两款新机。其中,redmi k90搭载骁龙8至尊版处理器、7100mah大电池及100w有线快充等多项旗舰配置,起售价为2599元,官方称其为k系列迄今为止最完整的标准版本。 图源:REDMI红米…

    2025年12月6日 行业动态
    200
  • Linux中如何安装Nginx服务_Linux安装Nginx服务的完整指南

    首先更新系统软件包,然后通过对应包管理器安装Nginx,启动并启用服务,开放防火墙端口,最后验证欢迎页显示以确认安装成功。 在Linux系统中安装Nginx服务是搭建Web服务器的第一步。Nginx以高性能、低资源消耗和良好的并发处理能力著称,广泛用于静态内容服务、反向代理和负载均衡。以下是在主流L…

    2025年12月6日 运维
    000
  • Linux journalctl与systemctl status结合分析

    先看 systemctl status 确认服务状态,再用 journalctl 查看详细日志。例如 nginx 启动失败时,systemctl status 显示 Active: failed,journalctl -u nginx 发现端口 80 被占用,结合两者可快速定位问题根源。 在 Lin…

    2025年12月6日 运维
    100
  • 华为新机发布计划曝光:Pura 90系列或明年4月登场

    近日,有数码博主透露了华为2025年至2026年的新品规划,其中pura 90系列预计在2026年4月发布,有望成为华为新一代影像旗舰。根据路线图,华为将在2025年底至2026年陆续推出mate 80系列、折叠屏新机mate x7系列以及nova 15系列,而pura 90系列则将成为2026年上…

    2025年12月6日 行业动态
    100
  • TikTok视频无法下载怎么办 TikTok视频下载异常修复方法

    先检查链接格式、网络设置及工具版本。复制以https://www.tiktok.com/@或vm.tiktok.com开头的链接,删除?后参数,尝试短链接;确保网络畅通,可切换地区节点或关闭防火墙;更新工具至最新版,优先选用yt-dlp等持续维护的工具。 遇到TikTok视频下载不了的情况,别急着换…

    2025年12月6日 软件教程
    100
  • Linux如何优化系统性能_Linux系统性能优化的实用方法

    优化Linux性能需先监控资源使用,通过top、vmstat等命令分析负载,再调整内核参数如TCP优化与内存交换,结合关闭无用服务、选用合适文件系统与I/O调度器,持续按需调优以提升系统效率。 Linux系统性能优化的核心在于合理配置资源、监控系统状态并及时调整瓶颈环节。通过一系列实用手段,可以显著…

    2025年12月6日 运维
    000
  • 曝小米17 Air正在筹备 超薄机身+2亿像素+eSIM技术?

    近日,手机行业再度掀起超薄机型热潮,三星与苹果已相继推出s25 edge与iphone air等轻薄旗舰,引发市场高度关注。在此趋势下,多家国产厂商被曝正积极布局相关技术,加速抢占这一细分赛道。据业内人士消息,小米的超薄旗舰机型小米17 air已进入筹备阶段。 小米17 Pro 爆料显示,小米正在评…

    2025年12月6日 行业动态
    000
  • 荣耀手表5Pro 10月23日正式开启首销国补优惠价1359.2元起售

    荣耀手表5pro自9月25日开启全渠道预售以来,市场热度持续攀升,上市初期便迎来抢购热潮,一度出现全线售罄、供不应求的局面。10月23日,荣耀手表5pro正式迎来首销,提供蓝牙版与esim版两种选择。其中,蓝牙版本的攀登者(橙色)、开拓者(黑色)和远航者(灰色)首销期间享受国补优惠价,到手价为135…

    2025年12月6日 行业动态
    000
  • Vue.js应用中配置环境变量:灵活管理后端通信地址

    在%ignore_a_1%应用中,灵活配置后端api地址等参数是开发与部署的关键。本文将详细介绍两种主要的环境变量配置方法:推荐使用的`.env`文件,以及通过`cross-env`库在命令行中设置环境变量。通过这些方法,开发者可以轻松实现开发、测试、生产等不同环境下配置的动态切换,提高应用的可维护…

    2025年12月6日 web前端
    000
  • VSCode选择范围提供者实现

    Selection Range Provider是VSCode中用于实现层级化代码选择的API,通过注册provideSelectionRanges方法,按光标位置从内到外逐层扩展选择范围,如从变量名扩展至函数体;需结合AST解析构建准确的SelectionRange链式结构以提升选择智能性。 在 …

    2025年12月6日 开发工具
    000
  • JavaScript动态生成日历式水平日期布局的优化实践

    本教程将指导如何使用javascript高效、正确地动态生成html表格中的日历式水平日期布局。重点解决直接操作`innerhtml`时遇到的标签闭合问题,通过数组构建html字符串来避免浏览器解析错误,并利用事件委托机制优化动态生成元素的事件处理,确保生成结构清晰、功能完善的日期展示。 在前端开发…

    2025年12月6日 web前端
    000
  • JavaScript响应式编程与Observable

    Observable是响应式编程中处理异步数据流的核心概念,它允许随时间推移发出多个值,支持订阅、操作符链式调用及统一错误处理,广泛应用于事件监听、状态管理和复杂异步逻辑,提升代码可维护性与可读性。 响应式编程是一种面向数据流和变化传播的编程范式。在前端开发中,尤其面对复杂的用户交互和异步操作时,J…

    2025年12月6日 web前端
    000
  • JavaScript生成器与迭代器协议实现

    生成器和迭代器基于统一协议实现惰性求值与数据遍历,通过next()方法返回{value, done}对象,生成器函数简化了迭代器创建过程,提升处理大数据序列的效率与代码可读性。 JavaScript中的生成器(Generator)和迭代器(Iterator)是处理数据序列的重要机制,尤其在处理惰性求…

    2025年12月6日 web前端
    000
  • 环境搭建docker环境下如何快速部署mysql集群

    使用Docker Compose部署MySQL主从集群,通过配置文件设置server-id和binlog,编写docker-compose.yml定义主从服务并组网,启动后创建复制用户并配置主从连接,最后验证数据同步是否正常。 在Docker环境下快速部署MySQL集群,关键在于合理使用Docker…

    2025年12月6日 数据库
    000
  • Xbox删忍龙美女角色 斯宾塞致敬板垣伴信被喷太虚伪

    近日,海外游戏推主@HaileyEira公开发表言论,批评Xbox负责人菲尔·斯宾塞不配向已故的《死或生》与《忍者龙剑传》系列之父板垣伴信致敬。她指出,Xbox并未真正尊重这位传奇制作人的创作遗产,反而在宣传相关作品时对内容进行了审查和删减。 所涉游戏为年初推出的《忍者龙剑传2:黑之章》,该作采用虚…

    2025年12月6日 游戏教程
    000
  • 如何在mysql中分析索引未命中问题

    答案是通过EXPLAIN分析执行计划,检查索引使用情况,优化WHERE条件写法,避免索引失效,结合慢查询日志定位问题SQL,并根据查询模式合理设计索引。 当 MySQL 查询性能下降,很可能是索引未命中导致的。要分析这类问题,核心是理解查询执行计划、检查索引设计是否合理,并结合实际数据访问模式进行优…

    2025年12月6日 数据库
    000
  • VSCode入门:基础配置与插件推荐

    刚用VSCode,别急着装一堆东西。先把基础设好,再按需求加插件,效率高还不卡。核心就三步:界面顺手、主题舒服、功能够用。 设置中文和常用界面 打开软件,左边活动栏有五个图标,点最下面那个“扩展”。搜索“Chinese”,装上官方出的“Chinese (Simplified) Language Pa…

    2025年12月6日 开发工具
    000
  • VSCode性能分析与瓶颈诊断技术

    首先通过资源监控定位异常进程,再利用开发者工具分析性能瓶颈,结合禁用扩展、优化语言服务器配置及项目设置,可有效解决VSCode卡顿问题。 VSCode作为主流的代码编辑器,虽然轻量高效,但在处理大型项目或配置复杂扩展时可能出现卡顿、响应延迟等问题。要解决这些性能问题,需要系统性地进行性能分析与瓶颈诊…

    2025年12月6日 开发工具
    000

发表回复

登录后才能评论
关注微信