Web Application Development Tutorial - Part 7: Authors: Database Integration
About This Tutorial
In this tutorial series, you will build an ABP based web application named Acme.BookStore
. This application is used to manage a list of books and their authors. It is developed using the following technologies:
- Entity Framework Core as the ORM provider.
- MVC / Razor Pages as the UI Framework.
This tutorial is organized as the following parts;
- Part 1: Creating the server side
- Part 2: The book list page
- Part 3: Creating, updating and deleting books
- Part 4: Integration tests
- Part 5: Authorization
- Part 6: Authors: Domain layer
- Part 7: Authors: Database Integration (this part)
- Part 8: Authors: Application Layer
- Part 9: Authors: User Interface
- Part 10: Book to Author Relation
Download the Source Code
This tutorial has multiple versions based on your UI and Database preferences. We've prepared a few combinations of the source code to be downloaded:
If you encounter the "filename too long" or "unzip error" on Windows, it's probably related to the Windows maximum file path limitation. Windows has a maximum file path limitation of 250 characters. To solve this, enable the long path option in Windows 10.
If you face long path errors related to Git, try the following command to enable long paths in Windows. See https://github.com/msysgit/msysgit/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path
git config --system core.longpaths true
Introduction
This part explains how to configure the database integration for the Author
entity introduced in the previous part.
DB Context
Open the BookStoreDbContext
in the Acme.BookStore.EntityFrameworkCore
project and add the following DbSet
property:
Then locate to the OnModelCreating
method in BookStoreDbContext
class in the same project and add the following lines to the end of the method:
This is just like done for the Book
entity before, so no need to explain again.
Create a new Database Migration
The startup solution is configured to use Entity Framework Core Code First Migrations. Since we've changed the database mapping configuration, we should create a new migration and apply changes to the database.
Open a command-line terminal in the directory of the Acme.BookStore.EntityFrameworkCore
project and type the following command:
This will add a new migration class to the project:
You can apply changes to the database using the following command, in the same command-line terminal:
If you are using Visual Studio, you may want to use
Add-Migration Added_Authors -c BookStoreDbContext
andUpdate-Database -Context BookStoreDbContext
commands in the Package Manager Console (PMC). In this case, ensure thatAcme.BookStore.Web
is the startup project andAcme.BookStore.EntityFrameworkCore
is the Default Project in PMC.
Implementing the IAuthorRepository
Create a new class, named EfCoreAuthorRepository
inside the Acme.BookStore.EntityFrameworkCore
project (in the Authors
folder) and paste the following code:
- Inherited from the
EfCoreRepository
, so it inherits the standard repository method implementations. WhereIf
is a shortcut extension method of the ABP Framework. It adds theWhere
condition only if the first condition meets (it filters by name, only if the filter was provided). You could do the same yourself, but these type of shortcut methods makes our life easier.sorting
can be a string likeName
,Name ASC
orName DESC
. It is possible by using the System.Linq.Dynamic.Core NuGet package.
See the EF Core Integration document for more information on the EF Core based repositories.
The Next Part
See the next part of this tutorial.