首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

EF 数据库连接约定(Connection String Conventions in Code First)

EF应用中没有做任何的配置.且在你自定义的数据库上下文类中没有调用DbContext带参的构造函数,那么当前应用对应的数据库上下文类,将会调用DbContext的默认无参的构造函数(EF默认规定的数据库连接...二、DbContext带string参数的构造函数 1、如果没有在数据库上下文进行其他额外的配置,然后调用DbContext中的带参的构造函数,传入你想要使用的数据库连接字符串,然后Code First...app.config/web.config配置文件中的连接字符串,表示你在应用程序中已经进行了配置,这一点要区分上面的方法. (1)、有Ado.Net使用经历的都知道,一般情况下,数据库连接字符串一般定义在...(2)、如果连接字符串的name属性值和上下文类名不一样,但是还是希望上下文使用配置文件的数据库连接进行数据库连接,这时就需要在上下文构造函数中调用DbContext的带string参数的构造函数,并传入连接字符串的...另外一种方式是传递给DbContext构造函数配置文件中的connectionString节点的name属性来指定上下文通过配置文件中connectionString来连接字符串,代码如下: public

1.5K90

EF Core 实现读写分离的最佳方案

前言 公司之前使用Ado.net和Dapper进行数据访问层的操作, 进行读写分离也比较简单, 只要使用对应的数据库连接字符串即可....而最近要迁移到新系统中,新系统使用.net core和EF Core进行数据访问. 所以趁着假期拿出一两天时间研究了一下如何EF Core进行读写分离....最简单的思路就是使用手动切换EF Core上下文的连接, 即context.Database.GetDbConnection().ConnectionString = "xxx", 但必须要先创建上下文...我认为最理想的方式是要避免数据库连接的切换, 且能够适应多DbContext的情况, 在创建上下文实例时,就指定好是访问主库还是从库, 而不是在后期再进行数据库切换....IUnitOfWork, 在DI中的生命周期是Scoped,在销毁的同时会销毁数据库上下文对象, 下面是它的实现, 为了提高性能使用了Expression来代替反射.

2.3K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    .NET Core采用的全新配置系统: 将配置保存在数据库中

    我们在《聊聊默认支持的各种配置源》和《深入了解三种针对文件(JSON、XML与INI)的配置源》对配置模型中默认提供的各种ConfigurationSource进行了深入详尽的介绍,如果它们依然不能满足项目中的配置需求...目录 一、在应用中使用自定义的DbConfigurationSource 二、ApplicationSetting & ApplicationSettingsContext 三、DbConfigurationSource...四、DbConfigurationProvider 五、扩展方法AddDatabase 一、在应用中使用自定义的DbConfigurationSource 我们将这个自定义ConfigurationSource...在重写的Load方法中,它会根据提供的Action创建ApplicationSettingsContext对象,并利用后者从数据库中读取配置数据并转换成字典对象并赋值给代表配置字典的...如果数据表中没有数据,该方法还会利用这个DbContext对象将提供的初始化配置添加到数据库中。

    1.3K80

    配置:自定义配置源

    在正式介绍它的实现之前,我们先来看看它在项目中的应用。我们将配置保存在SQL Server数据库中的某个数据表中,并采用Entity Framework Core来读取它。...我们将连接字符串作为配置定义在一个名为“appSettings.json”的JSON文件中。....; Pwd = ..." } } 在如下所示的演示程序中,我们首先创建了一个ConfigurationBuilder对象,并在它上面注册了一个指向connectionString.json文件的JsonConfigurationSource...在重写的Load方法中,它会根据提供的Action创建ApplicationSettingsContext对象,并利用它从数据库中读取配置数据并转换成字典对象并赋值给代表配置字典的...如果数据表中没有数据,该方法还会利用这个DbContext对象将提供的初始化配置添加到数据库中。

    72840

    Entity Framework应用:使用Code First模式管理数据库创建和填充种子数据

    一、管理数据库连接 1、使用配置文件管理连接之约定 在数据库上下文类中,如果我们只继承了无参数的DbContext,并且在配置文件中创建了和数据库上下文类同名的连接字符串,那么EF会使用该连接字符串自动计算出数据库的位置和数据库名...DbContext类的有参构造函数,这样一来,我们的数据库上下文就会开始使用该连接字符串了,在Program类中输出Name和Age字段的值: 1 using ExistsConnectionString.EF...注意:如果在配置文件中还有一个和数据库上下文类名同名的ConnectionString,那么就会使用这个同名的连接字符串。...二、管理数据库创建 首次运行EF Code First应用时,EF会做下面的这些事情: 1、检查正在使用的DbContext类。 2、找到该上下文类使用的connectionString。...1、设置初始化策略 EF默认使用CreateDatabaseIfNotExists作为默认初始化器,如果要覆盖这个策略,那么需要在DbContext类中的构造函数中使用Database.SetInitializer

    1.2K20

    .NET Core开发实战(第29课:定义仓储:使用EF Core实现仓储层)--学习笔记

    29 | 定义仓储:使用EF Core实现仓储层 首先定义仓储层的接口,以及仓储层实现的基类,抽象类 仓储层的接口 namespace GeekTime.Infrastructure.Core {...}); } 这一行代码的调用位置是在 ConfigureServices 里面 // 从配置中获取字符串 services.AddMySqlDomainContext(Configuration.GetValue...("Mysql")); 启动程序,运行过程中 EF 框架会根据定义的实体映射关系生成数据库,可在 Mysql 数据库中查看生成结果 接着丰富一下 Order 的映射关系 namespace...这样一来就完成了仓储层的定义,可以看到仓储层的代码非常的薄,仅仅包含了一些接口的定义和类的继承,需要自定义一些方法的时候,可以在仓储层定义一些特殊方法,比如 AddABC 等特殊的逻辑都可以在这里去实现...,可以很清晰的看到,是在 EntityConfiguration 这个目录下面,为每一个模型定义一个映射类,当领域模型越来越复杂,数据库的结构越来越复杂的时候,这样的组织结构会非常的清晰 ?

    2.4K11

    使用开源框架Sqlsugar结合mysql开发一个小demo

    mysql数据库使用Sqlsugar 1.新建解决方案,自定义解决方案名称和保存路径 2.此时我们需要添加三个包,首先找到工具 =》NuGet包管理器 =>管理解决方案的NuGet程序包 ?...4.准备工作已经做完了,现在可以开始正文了 先贴一段代码,这个是我封装的一个操作数据库的一个类,我采用的是单例模式,不过有个弊端就是不能使用高并发的情况 public class DBContext<T...{ //可以在连接字符串中设置连接池pooling=true;表示开启连接池 //eg:min pool size=2;max poll...类,比如我这里是book和booktype,附加一段代码做个参考 [SugarTable("Books")]//指定数据库中的表名,要对应数据库的表名,否则会出错 public class...; } 其他操作数据库的例子参考孙凯旋的博客园吧,附链接 http://www.codeisbug.com/Doc/8/1123 例子到这里就结束了,分享一下,我在做这个过程中遇到的问题

    2.7K10

    【愚公系列】2023年02月 .NETC#知识点-使用控制台手搭webapi框架

    EF中 三、EFCore框架表配置详解 1.配置基类, 2.实体表统一配置 3.DBContext中应用配置 四、仓储配置 1.仓储基类 2.仓储实现类 五、Autofac配置 1.注入DBContext...本文涉及的知识量巨大主要有如下: EFCore Autofac Serilog Swagger 非常多底层知识 一、使用控制台手搭webapi框架 1.配置文件 appsettings.Development.json...EF实体,接口可以设置一个泛型,来泛化我们的主键类型,因为可能存在不同的表的主键类型也不一样。...中作为DBSets,再也不需要一个个写DBSet了,可以用过DbContext.Set()获取用户的DBSet。...注入到仓储的构造中 .UsingConstructor(typeof(LibraryDbContext)) .AsImplementedInterfaces

    1.5K10

    《ASP.NET Core 微服务实战》-- 读书笔记(第5章)

    仓储 在本节,我们要升级位置服务让它使用 Postgres 为了完成这一过程,需要创建一个新的仓储实现,以封装 PostgreSQL 的客户端通信 回顾一下位置仓库的接口 public interface...services.AddScoped(); services.AddMvc(); } 数据库是一种后端服务 在本例中...需要让它在依赖注入中可用,这样位置仓储才能使用它 public void ConfigureServices(IServiceCollection services) { //var transient...、团队成员的机器上运行,又要能在云上自动运行 这就是我喜欢搭配使用 Wercker 和 Docker 的原因 试运行数据服务 使用特定参数启动 Postgres $ docker run -p 5432...,可以使用 docker ps 以及 docker kill 找到位置服务所在的 Docker 进程并终止它 然后通过之前用过的命令重新启动服务

    64020

    Transformer 在RxJava中的使用

    早在 RxJava1.x 版本就有了Observable.Transformer、Single.Transformer和Completable.Transformer,在2.x版本中变成了ObservableTransformer...其实,在大名鼎鼎的图片加载框架 Glide 以及 Picasso 中也有类似的transform概念,能够将图形进行变换。...RxLifecycle中的LifecycleTransformer trello出品的RxLifecycle能够配合Android的生命周期,防止App内存泄漏,其中就使用了LifecycleTransformer...在我的项目中也使用了知乎的RxLifecycle,根据个人的习惯和爱好,我对LifecycleTransformer稍微做了一些修改,将五个Transformer合并成了一个。....... } 如果你想在RxJava的链式调用中也使用缓存,还可以考虑使用transformer的方式,下面我写了一个简单的方法 /** * Created by Tony Shen on

    7.8K20

    XML 在SQLServer中的使用

    当你用XML数据类型配置这些对象中的一个时,你指定类型的名字就像你在SQLServer 中指定一个类型一样。 XML的数据类型确保了你的XML数据被完好的构建保存,同时也符合ISO的标准。...在定义一个XML数据类型之前,我们首先要知道它的几种限制,如下: 一个实例的XML列不能包含超过2GB的数据。 一个XML的列不能是索引。 XML对象不能使用Group By的子句中。...在Listing16中,我指定了[1]在Xquery表达式的后面,所以结果集将只返回第一个人的名字。...除了在表达式中定义你的XQuery表达式,你也能聚合的功能来进一步定义你的查询和操作数据。...总结 我们基本上了解了XML在SQLServer 中的简单应用,从定义到使用方法。也看到了query()检索子集,也能使用value()检索独立的元素属性的值。

    7.7K70
    领券