options.UseOracle()在EF Core中不可用

问题描述 投票:2回答:2

将EF Core与Oracle.ManagedDataAccess.Core一起使用(2.18.3)

尝试添加DB上下文时无法调用“options.UseOracle”方法。

编译器抛出错误:'DbContextOptionsBuilder'不包含'UseOracle'的定义,并且没有可访问的扩展方法'UseOracle'接受类型'DbContextOptionsBuilder'的第一个参数(你是否缺少using指令或程序集引用?)

请参阅下面的代码,它是最后一行无法编译,我的nuget参考包括Oracle.ManagedDataAccess.Core(2.18.3)

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.HttpsPolicy;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using EfGetStarted.AspNetCore.NewDb.Models;
using Microsoft.EntityFrameworkCore;
using Oracle.ManagedDataAccess.Client;

namespace EfGetStarted.AspNetCore.NewDb
{
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.Configure<CookiePolicyOptions>(options =>
            {
                // This lambda determines whether user consent for non-essential cookies is needed for a given request.
                options.CheckConsentNeeded = context => true;
                options.MinimumSameSitePolicy = SameSiteMode.None;
            });


            services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);



            var ora_conn = "User Id=xyz;Password=pwd;Data Source=(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = ORA01)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = ora1)))";
            services.AddDbContext<BloggingContext>(options => options.UseOracle(ora_conn));


        }
c# asp.net-core entity-framework-core oracle.manageddataaccess
2个回答
3
投票

尝试

PM> Install-Package Oracle.EntityFrameworkCore -Version 2.18.0-beta3

0
投票

我在下载oracle.entityframeworkcore.2.18.0-beta3.nupkg包并添加'IncludePrerelease'之后设法安装它:

Install-Package Oracle.EntityFrameworkCore -IncludePrerelease -Source C:\Temp\

一切正常但是当试图通过id获取记录时,例如:Table.SingleOrDefaultAsync(m => m.Id == id);我得到错误:(sql命令未正确结束)

© www.soinside.com 2019 - 2024. All rights reserved.