按名称搜索而不是ID

时间:2016-01-26 21:17:34

标签: linq asp.net-web-api2

我正在学习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();,但我仍然遇到同样的错误。

1 个答案:

答案 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;