Как вы обрабатываете продолжения в WCF-OData с помощью URL-запроса? - PullRequest
5 голосов
/ 01 апреля 2011

Я работаю со службой данных WCF, указывающей на конечную точку OData.Если я использую DataServiceQuery, я могу управлять продолжением без каких-либо проблем.

var collection = new DataServiceCollection<T>();
collection.LoadCompleted += (sender, e) =>
    {
        if (e.Error != null)
        {
            callback(null, e.Error);
            return;
        }

        var thisCollection = (DataServiceCollection<T>) sender;
        if (thisCollection.Continuation != null)
        {
            thisCollection.LoadNextPartialSetAsync();
        }
        else
        {
            var items = thisCollection.ToList();
            callback(items, e.Error);
        }
    };
collection.LoadAsync(query);

Однако я не понимаю, как можно сделать то же самое для метода DataServiceContext.BeginExecute (string url, ...).

_odataContext.BeginExecute<T>(new Uri(requestUrl), x =>
{
    var items = _odataContext.EndExecute<T>(x);

    //not sure how to get the rest of the items with this method
});

Как использоватьметод запроса на основе URL, но все еще получить поддержку продолжения?

Ответы [ 3 ]

3 голосов
/ 01 апреля 2011

Синхронная выборка (для упрощения):

var r = ctx.Execute<Product>(new Uri("http://services.odata.org/Northwind/Northwind.svc/Products"));
QueryOperationResponse<Product> response = (QueryOperationResponse<Product>)r;
response.Count();
Console.WriteLine(response.GetContinuation());

Вкратце, метод Execute возвращает экземпляр QueryOperationResponse, который реализует IEnumerable, но также предоставляет продолжение.

2 голосов
/ 02 декабря 2013

Используйте ленивый перечислитель

public IEnumerable<Product> GetProducts()
{
    Uri request = new Uri("http://services.odata.org/Northwind/Northwind.svc/Products");

    var response = (QueryOperationResponse<Product>)ctx.Execute<Product>(request);

    while (true)
    {
        foreach (Product p in response)
        {
            yield return p;
        }

        var continuation = response.GetContinuation();
        if (continuation == null)
        {
            yield break;
        }

        response = ctx.Execute(continuation);
    }
}
2 голосов
/ 02 апреля 2011

Для полноты вот полная функция, которая следует за продолжениями для запросов URL.

public void ExecuteFullQuery<T>(Uri requestUrl, Action<IEnumerable<T>> callback)
{
    var list = new List<T>();
    ExecuteFullQueryImpl(requestUrl, list, callback);
}

private void ExecuteFullQueryImpl<T>(Uri requestUrl, List<T> items, Action<IEnumerable<T>> callback)
{
    _odataContext.BeginExecute<T>(requestUrl, x =>
    {
        var results = _odataContext.EndExecute<T>(x);
        if (results != null)
            items.AddRange(results.ToList());

        var response = (QueryOperationResponse<T>)results;
        var continuation = response.GetContinuation();
        if (continuation != null)
        {
            ExecuteFullQueryImpl(continuation.NextLinkUri, items, callback);
        }
        else
        {
            callback(items);
        }
    },
    null);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...