.NET Core 2.x получает строку подключения из appsettings.json в классе dbcontext - PullRequest
0 голосов
/ 16 ноября 2018

У меня проблема с установкой строки подключения в моем классе DBContext. Я знаю, что могу внедрить IConfiguration в конструктор SqlLiteDbcontext или использовать шаблон IOption, но в CRUD.cs я уже использую конструктор без параметров. Я ищу решение, которое не требует модификации CRUD.cs.

    public class SqliteDbContext : DbContext
    {
        public SqliteDbContext() : base()
        {
        }

        public SqliteDbContext(DbContextOptions<SqliteDbContext> options) : base(options)
        {
        }
 protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder.UseSqlite("Data Source=App_Data/sqlite.db");

            optionsBuilder.EnableSensitiveDataLogging(true);
        }

Startup.cs

public void ConfigureServices(IServiceCollection services)
        {
            services.AddAuthentication(IISDefaults.AuthenticationScheme);
            services.AddMemoryCache();
            services.AddMvc();
            // Adds services required for using options.
            //services.AddOptions();

            services.Configure<MvcOptions>(options =>
            {
            });

            services.AddDbContext<SqliteDbContext>(options =>
                options.UseSqlite(Configuration.GetConnectionString("Sqlite")));

CRUD.cs

 public partial class CRUD<T> where T : class, ICreatedDate, IId
    {
        private SqliteDbContext db;
        private DbSet<T> DbSet => db.Set<T>();

        public List<T> Read()
        {
            using (db = new SqliteDbContext())
            {
                return DbSet.ToList();
            }
        }
//...

1 Ответ

0 голосов
/ 16 ноября 2018

Вы не должны использовать Entity Framework в ASP.NET Core.У вас есть внедрение зависимостей и правильно настроенный контекст EF, поэтому вы должны использовать это.По сути это означает:

  1. Никогда не создавайте контекст базы данных вручную, используя new.Всегда вставляйте контекст как зависимость.
  2. Не переопределяйте метод OnConfiguring в базе данных для настройки контекста.Ожидается, что конфигурация будет передана как DbContextOptions, так что сам контекст не отвечает за настройку конфигурации.
  3. Избегайте пустого конструктора для контекста вашей базы данных, чтобы избежать неправильного использования, когда контекст остается ненастроенным.

Таким образом, ваш код должен выглядеть следующим образом:

public class SqliteDbContext : DbContext
{
    public SqliteDbContext(DbContextOptions<SqliteDbContext> options) : base(options)
    { }

    // define your database sets
    public DbSet<Entity> Entities { get; set; }
}

public class CRUDService<T>
{
    private readonly SqliteDbContext db;
    CRUDService(SqliteDbContext database)
    {
        db = database;
    }

    public List<T> Read()
    {
        return db.Set<T>().ToList();
    }
}

SqliteDbContext будет автоматически предоставлен контейнером ввода зависимостей.Вам просто нужно ввести зависимость для ее правильного разрешения.

Кстати.Я бы вообще предложил вам избегать (общего) шаблона хранилища.Контекст базы данных в Entity Framework уже является единицей работы, и каждый набор баз данных уже является хранилищем.Так что вы можете просто использовать это напрямую.Вы мало что выиграете, добавив еще одну абстракцию поверх нее, особенно общую, поскольку это всегда будет вас ограничивать.

Кроме того, вам следует переименовать SqliteDbContext во что-то, что фактически описывает, какие данные в контекстеуправляет.Контекст не должен заботиться о том, какой базовый поставщик баз данных используется.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...