admin 发表于 2022-2-12 14:35:41

使用Hot Chocolate和.NET 6构建GraphQL应用(8) —— 实现Mutate添加数据 ...


<h2 id="系列导航">系列导航</h2>
<p><ahref="https://www.cnblogs.com/code4nothing/p/graphql-net6-0.html">使用Hot Chocolate和.NET 6构建GraphQL应用文章索引</a></p>
<h2 id="需求">需求</h2>
<p>在讨论完GraphQL中的查询需求后,这篇文章我们将演示如何实现GraphQL中的数据添加任务。</p>
<h2 id="思路">思路</h2>
<p>在GraphQL中,对数据进行查询使用<code>query</code>,而对于修改数据则需要使用<code>mutation</code>,包括新增和修改数据。Hot Chocolate在使用Mutation的逻辑上和使用Query的基本一致,但是需要根据需要定义用于创建或者更新的数据对象,所以我们直接进行实现。</p>
<h2 id="实现">实现</h2>
<p>为了保持简单,我们先定义以下两个类型:</p>
<pre><code class="language-c#">// 定义新增Post的参数
public record AddPostInput(string Title, string Author);

// 定义新增Post的返回对象
public record AddPostPayload(Post Post);
</code></pre>
<p>新建<code>Mutation.cs</code>用来定义相关接口:</p>
<ul>
<li><code>Mutation.cs</code></li>
</ul>
<pre><code class="language-c#">namespace PostGraphi.Api.GraphQL;

public class Mutation
{
    public async Task&lt;AddPostPayload&gt; AddPostAsync(AddPostInput input, IRepository&lt;Post&gt; repository)
    {
      return new AddPostPayload(await repository.AddAsync(new Post
      {
            Title = input.Title,
            Author = input.Author
      }));
    }
}

</code></pre>
<p>最后在注入服务的地方进行配置:</p>
<ul>
<li><code>ProgramExtensions.cs</code></li>
</ul>
<pre><code class="language-c#">builder.Services
    .AddGraphQLServer()
    .SetPagingOptions(new PagingOptions
    {
      MaxPageSize = 50,
      IncludeTotalCount = true
    })
    .AddFiltering()
    .AddProjections()
    .AddSorting()
    .AddQueryType&lt;Query&gt;()
    .AddMutationType&lt;Mutation&gt;()
    .AddMutationConventions(new MutationConventionOptions
    {
      ApplyToAllMutations = true,
      InputArgumentName = "input",
      InputTypeNamePattern = "{MutationName}Input",
      PayloadTypeNamePattern = "{MutationName}Payload",
      PayloadErrorTypeNamePattern = "{MutationName}Error",
      PayloadErrorsFieldName = "errors"
    })
    .AddType&lt;PostType&gt;();
</code></pre>
<p>这样就实现了新增Post的需求,下面我们来验证一下。</p>
<h2 id="验证">验证</h2>
<p>启动<code>Api</code>项目,调用接口:</p>
<p><img src="https://img2022.cnblogs.com/blog/2487237/202202/2487237-20220211104544617-1400586374.png" ></p>
<p>终端的日志输出如下:</p>
<pre><code class="language-bash"> Executed DbCommand (1ms) , 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);
Executed endpoint 'Hot Chocolate GraphQL Pipeline'
</code></pre>
<p>可以看到新建的Post已经存储到数据库中了,我们可以通过查询接口来获取详情:</p>
<p><img src="https://img2022.cnblogs.com/blog/2487237/202202/2487237-20220211104851825-1533915064.png" ></p>
<h2 id="总结">总结</h2>
<p>在本文中我们实现了简单的新增Post操作,这里还有一些涉及到错误处理的内容,我没有在文章中演示,可以参考官方文档 <ahref="https://chillicream.com/docs/hotchocolate/defining-a-schema/mutations/#errors">Errors</a>,在自定义异常对象后,有三种方式可以进行错误处理:直接返回异常;使用异常工厂方法;使用构造函数。甚至可以在<code>AggregateExceptions</code>中一次性返回多个异常。基本思路都是通过添加属性<code></code>来实现的。</p>
<p>在下一篇文章中,我们通过<code>Mutation</code>对已有数据进行更新。</p>

页: [1]
查看完整版本: 使用Hot Chocolate和.NET 6构建GraphQL应用(8) —— 实现Mutate添加数据 ...