SQL访问WebApi示例
时间: 2023-10-27 15:06:12 浏览: 94
下面是一个简单的示例,演示如何使用 SQL 查询数据,并将结果作为 JSON 返回给 Web API。
首先,创建一个 ASP.NET Core Web API 项目。在项目中添加一个名为“DataAccess”的文件夹。在该文件夹中创建一个名为“SqlDataAccess.cs”的类,该类将负责连接数据库并执行查询。
```csharp
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using Dapper;
namespace WebApi.DataAccess
{
public class SqlDataAccess
{
private readonly string _connectionString;
public SqlDataAccess(string connectionString)
{
_connectionString = connectionString;
}
public List<T> LoadData<T, U>(string sql, U parameters)
{
using IDbConnection connection = new SqlConnection(_connectionString);
List<T> rows = connection.Query<T>(sql, parameters).ToList();
return rows;
}
}
}
```
该类使用 Dapper ORM 库来执行查询。 `LoadData` 方法接收两个类型参数:`T` 表示返回的数据类型,`U` 表示查询参数的类型。
接下来,在“Controllers”文件夹中创建一个名为“DataController.cs”的控制器类。在该类中,我们将使用 `SqlDataAccess` 类从数据库中检索数据并将其作为 JSON 返回给客户端。以下是示例控制器类的代码:
```csharp
using Microsoft.AspNetCore.Mvc;
using WebApi.DataAccess;
namespace WebApi.Controllers
{
[ApiController]
[Route("[controller]")]
public class DataController : ControllerBase
{
private readonly SqlDataAccess _dataAccess;
public DataController(SqlDataAccess dataAccess)
{
_dataAccess = dataAccess;
}
[HttpGet]
public IActionResult Get()
{
// 这里是数据库查询,查询的结果将返回一个包含多个对象的列表
var results = _dataAccess.LoadData<SomeType>("SELECT * FROM SomeTable", null);
// 将结果作为 JSON 返回给客户端
return Ok(results);
}
}
}
```
在上面的代码中,我们使用 `SqlDataAccess` 类从数据库中检索数据。我们将查询结果作为包含多个对象的列表返回。然后,我们将列表作为 JSON 返回给客户端。
最后,我们需要将 `SqlDataAccess` 类注入到控制器中。在“Startup.cs”文件中的“ConfigureServices”方法中添加以下代码:
```csharp
services.AddTransient<SqlDataAccess>(_ => new SqlDataAccess(Configuration.GetConnectionString("DefaultConnection")));
```
现在,我们已经完成了一个简单的 Web API,它允许客户端使用 SQL 查询数据并将结果作为 JSON 返回。
阅读全文