我有一个多租户数据库,客户端之间有严格和关键的数据分离。在将其投入生产之前,我想知道我的方法是否有意义或可能导致问题(安全/性能/维护)。以下2个模型是典型场景:
public class Car
{
[Key, Column(Order=0)]
public int carId {get;set;}
[Key, Column(Order=1)]
public int clientId {get;set;}
...
public virtual ICollection<Component> components {get;set;}
}
public class Component
{
[Key, Column(Order=0)]
public int componentId {get;set;}
[Key, Column(Order=1)]
public int clientId {get;set;}
...
[ForeignKey("carId, clientId")]
public Car car {get;set;}
public int carId {get;set}
}
这样,每个模型都将 clientId 作为主键,强制它与 .Find() 一起使用,并强制它进入多对多关系的连接表。这意味着存在相当多的冗余,并且当查询实际上对数据分离非常安全时使用 clientId。
将 clientId 强制放入任何内容是否有意义,或者仅将其保留在父模型上是否更好?