--- title: Adding Search author: rick-anderson ms.author: riande manager: wpickett ms.date: 10/14/2016 ms.topic: article ms.assetid: d69e5529-8ef6-4628-855d-200206d962b9 ms.prod: aspnet-core uid: tutorials/first-mvc-app/search --- # Adding Search In this section you'll add search capability to the `Index` action method that lets you search movies by *genre* or *name*. Update the `Index` action method to enable search: [!code-csharp[Main](start-mvc/sample2/src/MvcMovie/Controllers/MoviesController.cs?range=256-267)] The first line of the `Index` action method creates a [LINQ](http://msdn.microsoft.com/en-us/library/bb397926.aspx) query to select the movies: ````csharp var movies = from m in _context.Movie select m; ```` The query is *only* defined at this point, it **has not** been run against the database. If the `searchString` parameter contains a string, the movies query is modified to filter on the value of the search string, using the following code: ````csharp if (!String.IsNullOrEmpty(searchString)) { movies = movies.Where(s => s.Title.Contains(searchString)); } ```` The `s => s.Title.Contains()` code above is a [Lambda Expression](http://msdn.microsoft.com/en-us/library/bb397687.aspx). Lambdas are used in method-based [LINQ](http://msdn.microsoft.com/en-us/library/bb397926.aspx) queries as arguments to standard query operator methods such as the [Where](http://msdn.microsoft.com/en-us/library/system.linq.enumerable.where.aspx) method or `Contains` used in the code above. LINQ queries are not executed when they are defined or when they are modified by calling a method such as `Where`, `Contains` or `OrderBy`. Instead, query execution is deferred, which means that the evaluation of an expression is delayed until its realized value is actually iterated over or the `ToListAsync` method is called. For more information about deferred query execution, see [Query Execution](http://msdn.microsoft.com/en-us/library/bb738633.aspx). > [!NOTE] > The [Contains](http://msdn.microsoft.com/en-us/library/bb155125.aspx) method is run on the database, not the c# code above. On the database, [Contains](http://msdn.microsoft.com/en-us/library/bb155125.aspx) maps to [SQL LIKE](http://msdn.microsoft.com/en-us/library/ms179859.aspx), which is case insensitive. Navigate to `/Movies/Index`. Append a query string such as `?searchString=ghost` to the URL. The filtered movies are displayed. ![image](search/_static/ghost.png) If you change the signature of the `Index` method to have a parameter named `id`, the `id` parameter will match the optional `{id}` placeholder for the default routes set in *Startup.cs*. [!code-csharp[Main](./start-mvc/sample2/src/MvcMovie/Startup.cs?highlight=5&name=snippet_1)] You can quickly rename the `searchString` parameter to `id` with the **rename** command. Right click on `searchString` **> Rename**. ![image](search/_static/rename.png) The rename targets are highlighted. ![image](search/_static/rename2.png) Change the parameter to `id` and all occurrences of `searchString` change to `id`. ![image](search/_static/rename3.png) The previous `Index` method: [!code-csharp[Main](./start-mvc/sample2/src/MvcMovie/Controllers/MoviesController.cs?highlight=1,8&range=256-267)] The updated `Index` method: [!code-csharp[Main](./start-mvc/sample2/src/MvcMovie/Controllers/MoviesController.cs?highlight=1,8&range=275-286)] You can now pass the search title as route data (a URL segment) instead of as a query string value. ![image](search/_static/g2.png) However, you can't expect users to modify the URL every time they want to search for a movie. So now you'll add UI to help them filter movies. If you changed the signature of the `Index` method to test how to pass the route-bound `ID` parameter, change it back so that it takes a parameter named `searchString`: [!code-csharp[Main](./start-mvc/sample2/src/MvcMovie/Controllers/MoviesController.cs?highlight=1&range=256-267)] Open the *Views/Movies/Index.cshtml* file, and add the `