как внедрить контекст базы данных в graphql-dotnet - PullRequest
1 голос
/ 22 октября 2019

ConfigureServices

services.AddSingleton<IServiceProvider>(c => new FuncServiceProvider(type => c.GetRequiredService(type)));
services.AddDbContext<Context>(options => options.UseSqlServer(configuration.GetConnectionString("Default")));

services.AddSingleton<Query>();
services.AddSingleton<Schema>();

services.AddGraphQL();

Настройка

app.UseGraphQL<Schema>();

Запрос

    public class Query : ObjectGraphType
    {
        public Query(IServiceProvider resolver)
        {
            var db = resolver.GetRequiredService<Context>();

            Name = "query";
            Field<ListGraphType<Types.Note>>("notes", resolve: _ => db.Notes.AsAsyncEnumerable());
        }
    }

выполнение конечной точки GraphQL приводит к следующему исключению

System.InvalidOperationException: Невозможно разрешить заданную службу «Models.Database.Context» из корневого поставщика.

некоторые дополнительные сведения.

1 Ответ

0 голосов
/ 22 октября 2019

Query и Schema также должны быть ограничены, если они хотят использовать преимущество DbContext, которое добавляется в качестве области по умолчанию.

services.AddDbContext<Context>(options => options.UseSqlServer(configuration.GetConnectionString("Default")));

services.AddScoped<Query>();
services.AddScoped<Schema>();

services.AddGraphQL()
    .AddGraphTypes(ServiceLifetime.Scoped);;

И Context должнобыть явно введенным

public class Query : ObjectGraphType {
    public Query(Context db) {
        Name = "query";
        Field<ListGraphType<Types.Note>>("notes", resolve: _ => db.Notes.AsAsyncEnumerable());
    }
}
...