我将 Entity Framework 6 与租户隔离的应用程序一起使用。我通过查看请求主机名来确定租户,然后在整个应用程序中使用它,将其设置在租户拥有的记录中,等等。
每个上下文都会在请求结束时处理。但是,由于租户查找非常频繁,我实际上每个主机名只执行一次,然后将对象放入内存中的只读字典中。
这里的问题是,如果您什么都不做,您最终会得到与请求一样多的重复租户记录(直到由于现在模糊的查询而开始抛出问题,无论如何)。
我最初通过在数据存储的构造函数中添加对 DbSet.Attach() 的调用并附加当前租户来解决此问题。但是,如果您同时有多个请求,则会收到一个异常通知,您不能将同一个对象附加到多个上下文:“一个实体对象不能被多个 IEntityChangeTracker 实例引用。” 由于我偶尔会通过访问页面太快而在我的开发机器上触发它,我无法想象它适合生产。
我尝试通过在保存之前添加此调用来更改内容:
Context.ChangeTracker.Entries<Tenant>().Single().State = EntityState.Unchanged;
好吧,那也行不通。我收到错误“无法定义两个对象之间的关系,因为它们附加到不同的 ObjectContext 对象。”
好的...那我该怎么做呢?我要做的就是(就最终的 SQL 结果而言)最终得到具有对现有租户行 PK 的外键引用的各种行。
我发现引用 EF4 的一些东西建议了 Detach 方法,但我不确定我是否打算再调用它,因为它现在从 DbSet 的公共接口中隐藏了。如果我是,我不确定在哪里。当我第一次检索记录?
编辑:似乎确实有效的一个选项是转到上下文并根据缓存记录的 ID 提取租户记录。但是,现在我要无缘无故地查询数据库。