AspNetCore.Docs/aspnetcore/includes/mvc-intro/sql.md

53 lines
2.1 KiB
Markdown
Raw Normal View History

# Work with SQLite in an ASP.NET Core MVC app
2017-06-21 08:32:24 +08:00
By [Rick Anderson](https://twitter.com/RickAndMSFT)
The `MvcMovieContext` object handles the task of connecting to the database and mapping `Movie` objects to database records. The database context is registered with the [Dependency Injection](xref:fundamentals/dependency-injection) container in the `ConfigureServices` method in the *Startup.cs* file:
[!code-csharp[](~/tutorials/first-mvc-app-xplat/start-mvc/sample/MvcMovie/Startup.cs?name=snippet2&highlight=6-8)]
2017-06-21 08:32:24 +08:00
## SQLite
The [SQLite](https://www.sqlite.org/) website states:
> SQLite is a self-contained, high-reliability, embedded, full-featured, public-domain, SQL database engine. SQLite is the most used database engine in the world.
There are many third party tools you can download to manage and view a SQLite database. The image below is from [DB Browser for SQLite](http://sqlitebrowser.org/). If you have a favorite SQLite tool, leave a comment on what you like about it.
![DB Browser for SQLite showing movie db](~/tutorials/first-mvc-app-xplat/working-with-sql/_static/dbb.png)
2017-06-21 08:32:24 +08:00
## Seed the database
Create a new class named `SeedData` in the *Models* folder. Replace the generated code with the following:
[!code-csharp[](~/tutorials/first-mvc-app/start-mvc/sample/MvcMovie/Models/SeedData.cs?name=snippet_1)]
2017-06-21 08:32:24 +08:00
If there are any movies in the DB, the seed initializer returns.
```csharp
if (context.Movie.Any())
{
return; // DB has been seeded.
}
```
<a name="si"></a>
### Add the seed initializer
2017-06-21 08:32:24 +08:00
Add the seed initializer to the `Main` method in the *Program.cs* file:
::: moniker range=">= aspnetcore-2.1"
[!code-csharp[](~/tutorials/first-mvc-app/start-mvc/sample/MvcMovie21/Program.cs)]
::: moniker-end
::: moniker range="<= aspnetcore-2.0"
[!code-csharp[](~/tutorials/first-mvc-app/start-mvc/sample/MvcMovie/Program.cs?highlight=6,16-32)]
::: moniker-end
2017-06-21 08:32:24 +08:00
### Test the app
Delete all the records in the DB (So the seed method will run). Stop and start the app to seed the database.
The app shows the seeded data.
![MVC Movie application open browser showing movie data](~/tutorials/first-mvc-app/working-with-sql/_static/m55.png)