дополнительные аспекты для исследования с помощью принадлежащих сущностей, в том числе коллекции, разбиение таблиц и вложение, но они выходят за рамки тематики настоящей книги. За более подробной информацией о принадлежащих сущностях обращайтесь в документацию по EF Core:
Функции SQL Server можно сопоставлять с методами C# и включать в операторы LINQ. В таком случае метод C# служит просто заполнителем, поскольку в генерируемый запрос SQL внедряется серверная функция. Поддержка сопоставления с табличными функциями была добавлена в EF Core к уже имеющейся поддержке сопоставления со скалярными функциями. Дополнительные сведения о сопоставлении с функциями базы данных ищите в документации:
Глобальный инструмент командной строки EF Core под названием
dotnet-ef
содержит команды, необходимые для создания шаблонов существующих баз данных в коде, для создания/удаления миграций баз данных и для работы с базой данных (обновление, удаление и т.п.). Чтобы пользоваться глобальным инструментом
dotnet-ef
, вы должны его установить с помощью следующей команды (если вы прорабатывали материал главы с самого начала, то уже сделали это):
dotnet tool install -- global dotnet-ef — version 5.0.1
На заметку! Из-за того, что EF Core 5 не является выпуском с долгосрочной поддержкой (LTS) при использовании глобальных инструментов EF Core 5 потребуется указывать версию.
Для проверки результата установки откройте окно командной строки и введите такую команду:
dotnet ef
Если глобальный инструмент был успешно установлен, тогда вы получите схематическое изображение единорога EF Core (талисмана команды разработчиков) и список доступных команд, подобный показанному ниже (на экране единорог выглядит лучше):
Use "dotnet ef [command] --help" for more information about a command.
Использование: dotnet ef [параметры] [команда]
Параметры:
– -version
Показать информацию о версии.
– h|--help Показать справочную информацию.
– v \--verbose Включить многословный вывод.
– -no-color Не использовать цвета в выводе.
– -prefix-output Снабжать вывод префиксами для выделения уровней.
Команды:
database Команды для управления базой данных.
dbcontext Команды для управления типами DbContext.
migrations Команды для управления миграциями.
Для получения дополнительной информации о команде применяйте dotnet ef [команда] --help.
В табл. 22.9 описаны три основных команды глобального инструмента EF Core. С каждой основной командой связаны дополнительные подкоманды. Как и все команды .NET Core, каждая команда имеет развитую справочную систему, которая доступна после ввода
– h
вместе с командой.
Команды EF Core выполняются в отношении файлов проектов .NET Core (не файлов решений). Целевой проект должен ссылаться на пакет NuGet инструментов EF Core по имени
Microsoft.EntityFrameworkCore.Design
. Команды работают с файлом проекта, расположенным в том же каталоге, где команды вводятся, или с файлом проекта из другого каталога в случае ссылки на него через параметры командной строки.
Для команд CLI глобального инструмента EF Core, которым требуется экземпляр класса, производного от
DbContext
(
Database
и
Migrations
), при наличии в проекте только одного такого экземпляра именно он и будет использоваться. Если экземпляров
DbContext
несколько, тогда конкретный экземпляр необходимо указывать в параметре командной строки. Экземпляр производного от
DbContext
класса будет создаваться с применением экземпляра класса, реализующего интерфейс
IDesignTimeDbContextFactory<TContext>
, если инструмент смог его обнаружить.
Если инструменту не удалось его найти, то экземпляр класса, производного от
DbContext
, будет создаваться с использованием конструктора без параметров. Если ни того и ни другого не существует, тогда команда потерпит неудачу. Обратите внимание, что вариант с конструктором без параметров требует наличия переопределенной версии
OnConfiguring
, что не считается хорошей практикой.
Лучший (и на самом деле единственный) вариант — всегда создавать реализацию