系列导航

使用Hot Chocolate和.NET 6构建GraphQL应用文章索引

需求

在讨论完GraphQL中的查询需求后,这篇文章我们将演示如何实现GraphQL中的数据添加任务。

思路

在GraphQL中,对数据进行查询使用query,而对于修改数据则需要使用mutation,包括新增和修改数据。Hot Chocolate在使用Mutation的逻辑上和使用Query的基本一致,但是需要根据需要定义用于创建或者更新的数据对象,所以我们直接进行实现。

实现

为了保持简单,我们先定义以下两个类型:

// 定义新增Post的参数
public record AddPostInput(string Title, string Author); // 定义新增Post的返回对象
public record AddPostPayload(Post Post);

新建Mutation.cs用来定义相关接口:

  • Mutation.cs
namespace PostGraphi.Api.GraphQL;

public class Mutation
{
public async Task<AddPostPayload> AddPostAsync(AddPostInput input, [Service] IRepository<Post> repository)
{
return new AddPostPayload(await repository.AddAsync(new Post
{
Title = input.Title,
Author = input.Author
}));
}
}

最后在注入服务的地方进行配置:

  • ProgramExtensions.cs
builder.Services
.AddGraphQLServer()
.SetPagingOptions(new PagingOptions
{
MaxPageSize = 50,
IncludeTotalCount = true
})
.AddFiltering()
.AddProjections()
.AddSorting()
.AddQueryType<Query>()
.AddMutationType<Mutation>()
.AddMutationConventions(new MutationConventionOptions
{
ApplyToAllMutations = true,
InputArgumentName = "input",
InputTypeNamePattern = "{MutationName}Input",
PayloadTypeNamePattern = "{MutationName}Payload",
PayloadErrorTypeNamePattern = "{MutationName}Error",
PayloadErrorsFieldName = "errors"
})
.AddType<PostType>();

这样就实现了新增Post的需求,下面我们来验证一下。

验证

启动Api项目,调用接口:

终端的日志输出如下:

[10:45:15 INF] Executed DbCommand (1ms) [Parameters=[@p0='?' (DbType = Guid), @p1='?', @p2='?' (Size = 13), @p3='?', @p4='?' (DbType = DateTime), @p5='?', @p6='?' (DbType = DateTime), @p7='?', @p8='?', @p9='?' (DbType = DateTime), @p10='?' (Size = 30)], CommandType='Text', CommandTimeout='30']
INSERT INTO "Posts" ("Id", "Abstraction", "Author", "Content", "Created", "CreatedBy", "LastModified", "LastModifiedBy", "Link", "PublishedAt", "Title")
VALUES (@p0, @p1, @p2, @p3, @p4, @p5, @p6, @p7, @p8, @p9, @p10);
[10:45:15 INF] Executed endpoint 'Hot Chocolate GraphQL Pipeline'

可以看到新建的Post已经存储到数据库中了,我们可以通过查询接口来获取详情:

总结

在本文中我们实现了简单的新增Post操作,这里还有一些涉及到错误处理的内容,我没有在文章中演示,可以参考官方文档 Errors,在自定义异常对象后,有三种方式可以进行错误处理:直接返回异常;使用异常工厂方法;使用构造函数。甚至可以在AggregateExceptions中一次性返回多个异常。基本思路都是通过添加属性[Error(typeof(SomeUserDefinedException))]来实现的。

在下一篇文章中,我们通过Mutation对已有数据进行更新。

最新文章

  1. awk命令简单介绍
  2. eclipse 打开是报错&quot;reload maven project has encountered a problem&quot;
  3. js库之art.dialog
  4. 基于JQuery+JSP的无数据库无刷新多人在线聊天室
  5. Android中使用Parcelable
  6. 401 Palindromes(回文词)
  7. iOS 极光推送
  8. angularjs中异常处理
  9. servlet和struts2一起使用,实现绝对路径下的图片输出到jsp页面
  10. 关于javascript
  11. Primary key and Unique index
  12. C++引用的作用
  13. Html 段落自动换行
  14. 洛谷P2405 non天平
  15. Linux(Ubuntu)换apt-get源
  16. 20175120彭宇辰 《Java程序设计》第九周学习总结
  17. nodejs 如何获取页面get、post传递过来的参数
  18. windows10激活工具,绿色无毒,不改浏览器主页
  19. DevExpress v17.2新版亮点—WPF篇(二)
  20. MVC框架定义

热门文章

  1. IIS部署php项目——discuz论坛
  2. nalu,在java中使用lambda查询数据库
  3. python+openpyxl 获取最大行数,不是真正想获取的行数,导致替换时,报”NoneType&#39; object has no attribute &#39;find&#39;
  4. Python_多任务:进程、线程、协程
  5. 工厂模式(python)
  6. Nginx 负载均衡服务器的下载与安装 【window10】
  7. Word2010制作电子印章
  8. List接口的实现类
  9. 5大最新云原生镜像构建工具全解析,3个来自Google,你了解几个?
  10. Solon 1.6.15 发布,增加部分jdk17特性支持