在 C# 中使用 OData 进行数据查询,你可以使用 Microsoft.OData.Client 库。以下是一个简单的示例,演示如何使用这个库来查询 OData 服务:
Install-Package Microsoft.OData.Client
Products
的实体,模型类可以定义如下:public class Product
{
public int Id { get; set; }
public string Name { get; set; }
public decimal Price { get; set; }
}
ODataClient
类连接到 OData 服务并查询数据:using System;
using System.Collections.Generic;
using System.Linq;
using Microsoft.OData.Client;
class Program
{
static void Main(string[] args)
{
// 创建 OData 客户端
Uri serviceUri = new Uri("https://api.example.com/odata");
ODataClient client = new ODataClient(serviceUri);
// 获取 `Products` 实体集
IQueryable<Product> productsQuery = client.Products;
// 执行查询并获取结果
try
{
List<Product> products = productsQuery.ToList();
Console.WriteLine("查询到的产品:");
foreach (var product in products)
{
Console.WriteLine($"ID: {product.Id}, 名称: {product.Name}, 价格: {product.Price}");
}
}
catch (Exception ex)
{
Console.WriteLine("查询过程中发生错误:");
Console.WriteLine(ex.Message);
}
}
}
在这个示例中,我们首先创建了一个 ODataClient
实例来连接到 OData 服务。然后,我们使用 IQueryable<Product>
类型的 productsQuery
变量来表示 Products
实体集。接着,我们调用 ToList()
方法执行查询并将结果存储在 products
列表中。最后,我们遍历列表并输出查询到的产品信息。
注意:这个示例假设 OData 服务使用的是默认的命名空间。如果你的 OData 服务使用了不同的命名空间,你需要在创建 ODataClient
实例时指定正确的命名空间。例如:
ODataClient client = new ODataClient(serviceUri, "http://example.com/odata/$metadata");