Почему я не получаю желаемого результата в Hot Chocolate GraphQL, используя встроенный фильтр?C#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Почему я не получаю желаемого результата в Hot Chocolate GraphQL, используя встроенный фильтр?

Сообщение Anonymous »

У меня есть ответ на запрос, как показано ниже. Здесь я хочу отфильтровать запись, в которой «itemState» имеет значение «Исключение». Я пытаюсь использовать фильтр сборки, но похоже, что он работает не так, как ожидалось. Я попробовал несколько подходов, но не получил желаемого.
Чего мне здесь не хватает?
Нужно ли мне писать собственный фильтр?
Код BE:

Код: Выделить всё

public partial class Query
{
[UseFiltering(typeof(ExceptionDetailsByStockNumberFilterType))]
public async Task GetExceptionDetailsByStockNumberAsync(
IReadOnlyList stockNumber,
ExceptionByStockNumberRequestDto exceptionByStockNumberRequest,
CancellationToken cancellationToken,
[Service(ServiceKind.Synchronized)] IExceptionService exceptionService)
=> await exceptionService.GetExceptionDetailsByStockNumbersAsync(stockNumber, exceptionByStockNumberRequest, cancellationToken);
}
ExceptionDetailsByStockNumberFilterType

Код: Выделить всё

 public class ExceptionDetailsByStockNumberFilterType: FilterInputType
{
protected override void Configure(IFilterInputTypeDescriptor descriptor)
{
descriptor.Ignore(x => x.Id);
descriptor.Ignore(x => x.CreatedBy);
descriptor.Ignore(x => x.StockNumber);
descriptor.Ignore(x => x.Vin);

base.Configure(descriptor);
}
}
ExceptionDetailsByStockDto

Код: Выделить всё

[GraphQLName("ExceptionDetailsDto")]
public class ExceptionDetailsByStockDto
{
public string Id { get; set; }
public string StockNumber { get; set; }
public string Vin { get; set; }
public IEnumerable[*] LineItems { get; set; }
public IEnumerable
 Payments { get; set; }
public string CreatedBy { get; set; }
}
Фактический ответ:

Код: Выделить всё

{
"data": {
"exceptionDetailsByStockNumber": [
{
"vin": "2G1WB58K381303600",
"lineItems": [
{
"itemState": "Reconciled",
"reconciliationStatus": "Matched"
},
{
"itemState": "Exception",
"reconciliationStatus": "Duplicate"
}
]
}
]
}
}
Желаемый результат:

Код: Выделить всё

{
"data": {
"exceptionDetailsByStockNumber": [
{
"vin": "2G1WB58K381303600",
"lineItems": [
{
"itemState": "Exception",
"reconciliationStatus": "Duplicate"
}
]
}
]
}
}
График QL:
с где: { lineItems: { all: { itemState: { eq: "Exception" } } }

Код: Выделить всё

query {
exceptionDetailsByStockNumber(
stockNumber: "2002705823"
where: { lineItems: { all: { itemState: { eq: "Exception" } } } }
) {
vin
lineItems {
itemState
reconciliationStatus
}
}
}
Другие подходы:

Подробнее здесь: https://stackoverflow.com/questions/787 ... built-filt
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C#»