按名称而不是 ID 搜索

Search by name instead of id

我正在学习 Asp.net web api 2.0,目前的 CRUD 方法只是按 id 搜索,所以我试图让它按书名搜索,但我没有成功.

我添加到 WebApiConfig.cs 的内容:

config.Routes.MapHttpRoute(
    name: "DefaultApi",
    routeTemplate: "api/{controller}/{name}",
    defaults: new { name = RouteParameter.Optional }
};

我遇到问题的部分:

// GET: api/Books/Name
[ResponseType(typeof(Book))]
public IHttpActionResult GetBook(string name)
{
    Book book = from a in db.Books where a.Title == name select a;

    if (book == null)
    {
        return NotFound();
    }
    else
    {
        return Ok(book);
    }
}

但是它会让我构建这个,在我尝试 运行 LINQ 查询的那一行我得到一个错误:Cannot implicitly convert type 'System.Linq.IQueryable<BookService.Models.Book>'to 'BookService.Models.Book'.

我尝试将查询更改为 Book book = db.Books.Where(a => a.Title == name).AsQueryable();,但我仍然遇到同样的错误。

它returns一个IQueryable的结果集。改变

Book book = from a in db.Books where a.Title == name select a;

var books  = from a in db.Books where a.Title == name select a;

然后您需要迭代结果集。

或者如果您只需要第一个结果集,那么您可以使用 FirstoreDefault

Book book = db.Books.FirstOrDefault(a => a.Title == name);