按名称而不是 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);
我正在学习 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);