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

DbSet在设置后的模拟中仍为空

表示在进行模拟设置后,DbSet对象仍然没有被正确地初始化或者没有正确地设置相关数据。DbSet是Entity Framework框架中的一个类,用于表示数据库中的表或视图。它可以用于执行各种数据库操作,如查询、插入、更新和删除等。

在模拟测试中,为了方便进行单元测试,可以使用模拟框架(如Moq)来模拟DbSet对象,以避免依赖实际的数据库或数据访问层。通过设置模拟对象的行为,可以模拟各种情况下的数据返回。

如果在设置后的模拟中DbSet仍然为空,可能存在以下几种可能的原因:

  1. 未正确设置模拟对象:在使用模拟框架时,需要明确设置模拟对象的行为,如模拟查询时返回的数据集合、模拟插入时的操作等。如果设置不正确,可能导致DbSet为空。
  2. 数据未正确初始化:模拟对象中的数据需要在设置前进行正确的初始化,以确保在模拟过程中可以正确返回数据。可能需要手动添加模拟数据或通过模拟框架提供的方法进行数据初始化。
  3. 未正确模拟数据库操作:在进行模拟测试时,需要正确模拟数据库操作的行为,如查询、插入、更新和删除等。如果模拟的数据库操作未能正确执行,可能导致DbSet为空。

为了解决这个问题,可以采取以下步骤:

  1. 确保正确设置模拟对象的行为:使用模拟框架时,需要详细了解框架的使用方法,正确设置模拟对象的行为,如返回的数据集合、模拟操作的结果等。
  2. 确保正确初始化数据:在设置模拟对象前,确保已正确初始化数据。可以手动添加一些模拟数据,或使用模拟框架提供的方法进行数据初始化。
  3. 检查模拟的数据库操作:确保模拟的数据库操作能正确执行,如查询时返回正确的结果集,插入时能正确添加数据等。可以通过调试或查看模拟框架的文档进行排查。

总结起来,如果在设置后的模拟中DbSet仍为空,需要检查模拟对象的设置、数据的初始化和模拟的数据库操作,确保它们的正确性。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

mongoDB设置权限登陆后,在keystonejs中创建新的数据库连接实例

# 问题 mongoDB的默认登陆时无密码登陆的,为了安全起见,需要给mongoDB设置权限登录,但是keystoneJS默认是无密码登陆的,这是需要修改配置来解决问题 # 解决 在keystone.js...中找到配置初始化方法,添加一个mongo 对象来设置mongoDB连接实例, keystone.init({ 'name': 'recoluan', 'brand': 'recoluan',...'mongo': 'mongodb://user:password@host:port/dbName', }); 1 2 3 4 5 复制 这里需要注意的是,mongoDB在设置权限登录的时候,首先必须设置一个权限最大的主账户...,它用来增删其他普通账户,记住,这个主账户时 无法 用来设置mongo对象的, 你需要用这个主账户创建一个数据库(下面称“dbName”),然后在这个dbName上再创建一个可读写dbName的普通账户...,这个普通账户的user和password和dbName用来配置mongo对象

2.4K10
  • EntityFramework Core 学习扫盲

    少数的几个CLR类型在不做处理的情况下,映射到数据库中时将存在可空选项,如string,int?,这种情况也在下列方式中做了说明。...主键 默认情况下,EF CORE会将实体中命名为Id或者[TypeName]Id的属性映射为数据库表中的主键。当然有些开发者不喜欢将主键命名为Id,EF CORE也提供了两种方式进行主键的相关设置。...进一步说,如果属性是整数或是Guid类型,那么该属性将会被EF CORE设置为自动生成。这是EF CORE的语法糖之一。 那由用户手动设置呢?...备用键 备用键在之前的小节中已经提过,使用以下代码配置的列将自动设置为唯一标识列。...常见的关系有1-1,1-n,n-n,除此以外,关系的两边还有可空不可空的控制。那么在EF CORE中,我们怎么实现这些关系呢?

    9.6K90

    EF 约定介绍

    当前环境为EF Code First开发模式中 一、EF默认约定 1、常用约定 (1)、当没有显示指定实体主键的时候,EF会默认将长得最像Id的属性(且类型为GUID)设为主键 (2)、设计实体时,当一个实体包含一个集合属性...因此,我们需要自定义一个ZdyNameDbContext,并继承DbContext,并在自定义DbContext中暴露需要暴露的类型,这样在Code First开发模式中,就可以使用 context(数据库上下文...) Convention EF中,两个实体间的关系是通过导航属性的方式来实现,每一个对象都能拥有一个它所参与的关系的导航属性,导航属性提供了一种方式在两端来操作这个关系来获取我们需要的数据,可以返回任何一方的引用对象...关联实体的主键名 (3)、关联实体的主键名 注: (1)、当外键关系被检测到,Code First会根据外键的可空性来推断关系的具体形式;如果外键属性是可空的,那么关系会被设置为可选的,否则,关系就是必选的.... (2)、当关联实体的外键属性被设置为不为空,Code First会设置级联删除,反之不会。

    1.6K100

    ASP.NET Core 使用 SQLite 教程,EF SQLite教程

    笔者版本 ASP.NET Core 版本为 2.1 ,选择的 NuGet 包版本为 2.11。 如果你的 .Net Core 是最新的,那么 NuGet 也选最新的即可。...需要建立一个上下文类和模型类,把模型类包含在上下文类中,上下文类中包含进来的模型类,将会生成对应的数据库表。 下面这代码不用自己操作,只需要看就行。...A、B都是模型类,因为可以被生成数据库表,所以A也可以叫实体类,B因为没有 DbSet ,所以B叫模型类,不叫实体类。 A类将会生成一个真实的数据库中的表,有对应关系,所以,他是“实体类”。...这里的构造函数内容为空,因为暂时没有什么要配置的。 步骤3 在构造函数下面加上代码,对模型类进行映射。...public DbSet Uaa { get; set; } //Dbset 映射成一个表 //Dbset 里面的Users即为使用的模型类 //Uaa Users

    4.7K50

    Entity Framework复杂类型属性映射

    出现上述错误的原因是我们没有初始化 Address 类,其中一个(后面我会讲解另一个解决方法)解决方法是在 new User(){} 内初始化 Address,修正后的代码如下: using (var...,应该在实体的构造函数中初始化复杂类型; 将制度属性添加到复杂类型中时,需进行空值检查; 尽量显式注册复杂类型。... Users { get; set; } } 代码改造后我们可以轻松的通过 变更追踪API 来访问数据的原始值和当前值。...同样,我们也可以通过链式调用,获取复杂了类型的属性或者设置复杂类型的属性: var user = efDbContext.Users.Find(1); var city = efDbContext.Entry...从上面的讲解我们卡一看到,用复杂类型很双,一直用一直爽,但是复杂类型还是有他的限制的: 不能共享引用:因为没有主键标识,不能被自身实例之外的任何对象引用; 没有优雅的方式标识空引用:即使查询出的数据为空

    69410

    【Unity3D 灵巧小知识点】 ☀️ | 层级面板中的 ‘小手指‘ 作用: 在Scen中将该物体设置为不可选中状态

    Unity 平台提供一整套完善的软件解决方案,可用于创作、运营和变现任何实时互动的2D和3D内容,支持平台包括手机、平板电脑、PC、游戏主机、增强现实和虚拟现实设备。...也可以简单把 Unity 理解为一个游戏引擎,可以用来专业制作游戏!...---- Unity小知识点学习 层级面板中的 ‘小手指’ 作用: 在Scen中将该物体设置为不可选中状态 在层级面板中有一个小手指一样的图标(我也不知道官方叫啥~) 当我们给物体选上之后,...他就会变成一个禁止的状态,就是上图中Plane物体前面那个样子 正常没选中的时候就是Cube前面那个样子的图标,点一下就会选中!...小手指的作用就是,当我们点了这个小手指,成为一个斜杠似的禁止状态时 在Scene场景中我们就没法通过鼠标来选中这个物体了 ! 演示效果: ----

    2.3K31

    Entity Framework Core 2.0 入门

    也可以): 输入用户名: 密码: 选择是否保存密码: 最后输入档案的名字: 随后VSCode将尝试连接该数据库, 成功后右下角会这样显示 (我这里输入有一个错误, 数据库名字应该是LearnEF): 随后在该文件中输入下面这个...而对于Owner来说, Company是必须的. 如果针对Owner想让Company是可空的, 那么CompanyId的类型就应该设置成int?....就是这种情况, 新的context一开始并没有追踪one这个数据. 通过使用Update方法, 追踪并设置状态为update. 然后更新到数据库....看一下Sql: 这个过程一共分两步: 1 插入主表, 2,使用刚插入主表数据的Id, 插入子表数据. 2.为数据库中的数据添加导航属性....这个匿名类只在方法内有效. 看下SQL: 可以看到SQL中只Select了匿名类里面需要的字段.

    3.2K80

    CSharpEntityFramework与CodeFirst实践

    正如生成的DbContext所说:“为您要在模型中包含的每种实体类型都添加 DbSet。”...,我们在该类中添加如下的DbSet属性,并将注释删除,更加直观的看一看当前的结构: public class BookDbDemo : DbContext { public BookDbDemo...换句话说,继承了DbContext的类就对应了某一个数据库,其连接属性由配置文件中的连接配置决定,并在DbContext中设置进去(基类构造函数设置),这个DbContext中的所有DbSet就对应到数据库中的表...首先,在Book类中增加这一属性,不设置Required特性: ......我们进入数据库中,看一看变化: 可以看到数据库中其他字段的值都没有发生变化,仅仅多出了这个字段,同时符合我们设置的可以为空的预期 删除属性 删除与增加同理,我们直接将Book实体类的属性删除,然后增加变更

    28310

    .NET EF Core(Entity Framework Core)

    4、EF中的一些类的命名空间以及一些方法的名字在EF Core中稍有不同。 5、EF不再做新特性增加。...修改表结构 想要限制Title的最大长度为50,Title字段设置为“不可为空”,并且想增加一个不可为空且最大长度为20的AuthorName(作者名字)属性。...主要规则: 1:表名采用DbContext中的对应的DbSet的 属性名。...,然后使用IsRowVersion()把这个属性设置为RowVersion类型,这样这个属性对应的数据库列就会被设置为ROWVERSION类型。...总结:如果有一个确定的字段要被进行并发控制,那么使用IsConcurrencyToken()把这个字段设置为并发令牌即可;如果无法确定一个唯一的并发令牌列,那么就可以引入一个额外的属性设置为并发令牌,并且在每次更新数据的时候

    45512

    分享 | C#编写的电影售票系统(附源码+数据库)

    在用户提交选择后,需要支付模块提示用户付款并完成出票。为了吸引用户,我们增加了会员的注册和登录模块,为会员用户提供折扣。...注册与购票的支付我们的处理是预留一个接口,当做简单模拟,实际使用可以调用支付宝或微信的支付接口。 在界面设计上,我们为系统添加了好看的背景图片。...当数据库发生改变时,只用重新生成代码,改动业务逻辑层的部分代码即可。 在实施的过程中,难点在于将三层结构进行划分,掌握各层之间的设计思路以及调用关系,下面内容就结合代码展示具体实现过程。...下面将以界面的为单位来对其实现过程进行描述: 》用户登录界面 用户将身份信息写入文本框后,用其输入的信息创建新的customer对象,通过调用BLL层的功能将输入内容与用户信息比对,最后用判断语句激活弹窗反馈登陆结果...》购票信息确认界面 在选定座位后,进行系统进行核算总的金额,然后显示所选座位信息以及应付的价钱。提示用户是否进行付款。

    4.8K82

    EF Core的增删改查

    我没找到EF Core官方文档中对于这种方式的称呼,所以我就悄悄的抢注了一下为托管。 如果我们使用Config类(也就是 《C# 数据操作系列 - 7....而删除,如果在配置导航属性时,没有设置级联删除,删除当前元素,如果另一端的外键是可空类型的,并不会删除导航属性另一端的元素只会设置外键指向为NULL,如果另一端外键是不可空的,那么就会同时删除。...: 行为名称 对内存中的依赖项/子项的影响 对数据库中的依赖项/子项的影响 Cascade 删除实体 删除实体 ClientSetNull(默认) 外键属性设置为 null None SetNull 外键属性设置为...null 外键属性设置为 null Restrict None None 而对于不可为NULL的外键来说,枚举DeleteBehavior的值起以下作用: 行为名称 对内存中的依赖项/子项的影响 对数据库中的依赖项...EF Core在调用 ToList的时候,会将已调用的方法和Linq转换成SQL语句,并正式向数据库发起查询。如果出现了在Linq中调用三方方法或者自己写的工具方法的话,可能会提示不受支持。

    3.2K20

    ASP.NET 6 使用工作单元操作 MongoDB

    在MongoDB中,所谓的事务主要指的是多个文档的事务,其使用方式和传统关系型数据库差不多。但我们需要注意的是:多文档事务只能应用在副本集 或 mongos 节点上。...NET应用中进行事务 下面展示了在.NET应用中通过MongoDB Driver来进行事务的示例: using (var clientSession = mongoClient.StartSession...那么,如何在自己的项目中实现这个呢? 参考了一些资料后,自己实现了一个基础小组件,暂且叫它:EDT.MongoProxy吧,我们来看看它是如何实现的。...单例的MongoClient 基于MongoDB的最佳时间,对于MongoClient最好设置为单例注入,因为在MongoDB.Driver中MongoClient已经被设计为线程安全可以被多线程共享,....NET操作事务,重点介绍了EDT.MongoProxy这个小组件的设计,让我们可以在ASP.NET 6应用中通过数据仓储(Repository)和工作单元(UnitOfWork)的模式来快速方便地操作

    33410

    .NET 云原生架构师训练营(模块二 基础巩固 EF Core 介绍)--学习笔记

    多出来的对事务、连接池、迁移、种子数据等一些功能 多数情况下 ORM 生成的 SQL 脚本比你自己写的要好 Repository 仓储 在领域层和数据映射层之间,像一个内存级别的领域对象集合 为领域业务的单元测试提供替换点...UnitOfWork 工作单元 一个工作单元在一个事务范围内保留所有对数据库的变更,在这个工作单元结束的时候一次性提交所有改动到数据库 DB Context 与 DB Set DB Context(UnitOfWork...工作单元) DB Set(Repository 仓储) EF Core 提供一个 DB Context 和多个 DB Set 组合完成数据查询和更新操作的 ORM 框架 EF Core快速开始示例 创建一个空的...中添加了DbContext的注入 // 安装dotnet tool ef工具 dotnet tool install --global dotnet-ef // 以下命令需要在api项目的目录下执行...Postman 中添加环境变量 ?

    82310

    Entity Framework 约定

    如果我们定义的模型由继承层次,只需要为基类定义一个DbSet属性即可(如果派生类与基类在同一个程序集,派生类将会被自动包含),代码如下: public class Department { public...二、关系约定 在数据库中,我们可以通过多张表的关联查询出数据,这多张表之间的关联,就是他们的关系。同样,也可以在模型中定义这样的关系。...当EF检测出外键属性后,会根据外键属性是否为空来判断关系,如果外键可以为空,那么模型之间的关系将会配置成可选的,Code First 不会再关系上配置级联删除。...自定义约定包含一个约定接口 IConvention,IConceptualModelConvention 是概念模型接口,在模型创建后被调用,IStoreModelConvention 接口为存储模型接口...,在模型创建之后用于操作对模型的存储,***自定义类约定***都必须在 OnModelCreating 方法中显式配置,例如我们要将模型中类型为DateTime的属性映射为datetime2,可进行如下配置

    1.3K10

    .NET 云原生架构师训练营(模块二 基础巩固 EF Core 介绍)--学习笔记

    多出来的对事务、连接池、迁移、种子数据等一些功能 多数情况下 ORM 生成的 SQL 脚本比你自己写的要好 Repository 仓储 在领域层和数据映射层之间,像一个内存级别的领域对象集合 为领域业务的单元测试提供替换点...集中数据库访问逻辑 24.jpg UnitOfWork 工作单元 一个工作单元在一个事务范围内保留所有对数据库的变更,在这个工作单元结束的时候一次性提交所有改动到数据库 DB Context 与...ORM 框架 EF Core快速开始示例 创建一个空的 web api 项目 添加 Pomelo.EntityFrameworkCore.Mysql 的 nuget 包引用 创建实体 创建 DbContext...public DbSet Assistants { get; set; } public DbSet中添加了DbContext的注入 // 安装dotnet tool ef工具 dotnet tool install --global dotnet-ef // 以下命令需要在api项目的目录下执行

    95511

    FreeSql.DbContext ,向"不是真正的 ORM" 说拜拜

    目前定义的规则如下: 文字规则略显复杂,后边有代码演示,以及图文介绍在 sqlite 和 sqlserver 下的测试过程。...entitys 主键值,是否存在于 states 中,存在时报错; 验证 entitys 主键中存在自增: 若有,则立即开启 DbContext 事务,按数据库种类执行相应的方法,最终将返回的自增值,...,再删除; 进入【打包执行队列】; Select 立即执行队列中的命令(打包方式),以免脏读到未提交的数据; 查询完成时,更新 states 的值; 更新数据规则 对比 states 中存在的历史快照值...在 sqlserver 测试 其实大致与 sqlite 下相同,唯一的区别在于 AddRange 的处理方式,如图: ?...当插入单条时,采用了第一行代码的 SQL 命令; 当批量插入时,采用了后面看上去复杂的 SQL 命令; 所有传入的实体属性值在执行完成后,都会更新; 特别说明 FreeSql.DbContext 目前仍处于研究开发阶段

    1K30

    ASP.NET MVC5高级编程——(3)MVC模式的模型

    首先数据库中主外键的定义: 主键 外键 定义: 唯一标识一条记录,不能有重复的,不允许为空 表的外键是另一表的主键, 外键可以有重复的, 可以是空值 作用: 用来保证数据完整性 用来和其他表建立联系用的...模型对象中的属性如果设置为虚拟的,可以给EF提供一个指向C#类集的钩子(hook),并未EF启用了一些特性,如高效的修改跟踪机制(efficient change tracking mechanism)...该派生类具有一个或多个DbSet类型的属性,类型DbSet中的每一个T代表一个想要持久保存的对象。...在文件global.asax.cs中,可以在应用程序启动过程中设置一个初始化器: 源代码: ?...现在我们可以重新启动程序,因为我们设置的是DropCreateDatabaseAlways模式,所以如果不重启程序的话,会报错的: ? 错误为不能删除数据库,因为它正在使用!

    4.8K40
    领券