Ask a Question Deep Mutations You can perform deep mutations at multiple levels. Deep mutations do not alter linked objects, but they can add deeply-nested new objects or link to existing objects. To update an existing nested object, use the update mutation for its type. We use the following schema to demonstrate some examples. Schema: type Author { id: ID! name: String! @search(by: [hash]) dob: DateTime posts: [Post] } type Post { postID: ID! title: String! @search(by: [term, fulltext]) text: String @search(by: [fulltext, term]) datePublished: DateTime } Example: Adding deeply nested post with new author mutation using variables mutation addAuthorWithPost($author: addAuthorInput!) { addAuthor(input: [$author]) { author { id name posts { title text } } } } Variables: { "author": { "name": "A.N. Author", "dob": "2000-01-01", "posts": [ { "title": "New post", "text": "A really new post" } ] } } Example: Update mutation on deeply nested post and link to an existing author using variables The following example assumes that the post with the postID of 0x456 already exists, and is not currently nested under the author having the id of 0x123. Note This syntax does not remove any other existing posts, it just adds the existing post to any that may already be nested. mutation updateAuthorWithExistingPost($patch: UpdateAuthorInput!) { updateAuthor(input: $patch) { author { id posts { title text } } } } Variables: { "patch": { "filter": { "id": ["0x123"] }, "set": { "posts": [ { "postID": "0x456" } ] } } } The example query above can’t modify the existing post’s title or text. To modify the post’s title or text, use the updatePost mutation either alongside the mutation above, or as a separate transaction. ← Delete Mutations in GraphQL