2

我正在创建一个有效的突变,但我不确定它是否按照我认为的方式工作。但是,我想知道执行顺序是什么?

  • 异步
  • 从上到下同步
  • 同步随机顺序
  • 别的东西

我想确保在执行插入/更新插入之前从表中删除某些项目。使用以下突变查询字符串,这是否总是做我想要的,或者它不会不时工作,因为我认为它是同步的,但实际上它是异步的?

mutation MyMutation(...) {
  update_my_table_1(...) { }

  delete_my_table_2(...) { }

  insert_my_table_2(...) { }
}
4

1 回答 1

4

规格

如果操作是突变,则操作的结果是在突变根对象类型上执行突变的顶级选择集的结果。该选择集应连续执行。

预计突变操作中的顶级字段会对底层数据系统产生副作用。提供的突变的串行执行可确保在这些副作用期间免受竞争条件的影响。

根突变类型上的字段始终按顺序解析。任何其他类型(如查询根类型或任何“嵌套”类型)的顺序字段由实现决定,尽管在大多数(如果不是全部)实现中,这意味着这些字段是并行解析的。

所以在上面的例子中,insert_my_table_2直到 is 才会执行delete_my_table_2,直到 isdelete_my_table_2才会执行update_my_table_1

于 2020-06-17T15:36:59.363 回答