C#   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了c# – 在实体框架(Oracle或SQL Server)中检测dbms类型大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
实体框架如何通过代码检测它是从sql Server还是Oracle创建的?有没有 @H_502_7@返回源数据库类型的属性方法

解决方法

我想不出比获得 DbProviderFactory并检查其类型更好的方法.

如果您创建一个类库@R_301_2495@案并安装NUnit和EntityFramework nuget包,则可以运行以下命令.

using Sy@L_874_11@.Data.Common;
using Sy@L_874_11@.Data.Entity;
using Sy@L_874_11@.Diagnostics;
using NUnit.Framework;

namespace efProviderChooser
{
    public class myThing
    {
        public int id { get; set; }
    }

    public class MyContext : DbContext
    {
        public DbSet<myThing> Things { get; set; }
    }

    public class Test
    {
        [Test]
        public void CanGetProvider()
        {
            var context = new MyContext();          
            var dbProviderFactory = DbProviderFactories
                                     .GetFactory(
                                       context.Database.Connection);

            Debug.WriteLine(dbProviderFactory.GetType());
            //gives one of 
            //Sy@L_874_11@.Data.EntityClient.EntityProviderFactory
            //Sy@L_874_11@.Data.odbc.odbcFactory
            //Sy@L_874_11@.Data.oleDb.oleDbFactory
            //Sy@L_874_11@.Data.OracleClient.OracleClientFactory
            //Sy@L_874_11@.Data.sqlClient.sqlClientFactory
            //this list Could change!

            // here I get sqlClient
            Assert.That(dbProviderFactory.GetType().ToString().Contains("sqlClient"));
        }
    }
}

大佬总结

以上是大佬教程为你收集整理的c# – 在实体框架(Oracle或SQL Server)中检测dbms类型全部内容,希望文章能够帮你解决c# – 在实体框架(Oracle或SQL Server)中检测dbms类型所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。