我正在学习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();
,但我仍然遇到同样的错误。
答案 0 :(得分:3)
返回IQueryable的结果集。改变
gzencode($contents, 9, FORCE_DEFLATE)
gzdeflate...
zlib_encode($contents, -15);// RFC 1951 - raw deflate
zlib_encode($contents, 15);// RFC 1950 - zlib
到
Book book = from a in db.Books where a.Title == name select a;
然后你需要迭代结果集。
或者,如果您只需要第一个结果集,则可以使用FirstoreDefault
var books = from a in db.Books where a.Title == name select a;