在.net core中完美解决多租户分库分表的问题
2021-03-22 20:27
标签:cti 问题 sql 返回 creat on() 如何 mss col 前几天有人想做一个多租户的平台,每个租户一个库,可以进行水平扩展,应用端根据登录信息,切换到不同的租户库 计划用ef core实现,他们说做不出来,需要动态创建dbContext,不好实现 然而这个使用CRL很轻松就能解决了 以下为演示数据库,有两个库testdb和testdb2,查询结果如下 目标: 根据传入登录信息连不不同的库,查询返回结果,如登录人为01,返回d1.default,登录人为02 返回 d2.default 实际上这个需求就是分库分表的实现,通过设置数据库/表映射关系,根据传入的定位数据进行匹配,找到正确的库表配置,生成数据访问对象 以core控制台程序为例 上面代码中,通过SetLocation方法传入定位数据Code,通过QueryItem方法查询出数据并打印出来 通过services.AddCRL 这里完全符合core注入规范,可以通过配置或数据库存储动态读取定位设置 在Init方法里,实现了两个操作,通过RegisterLocation定义如何根据定位数据Code,返回不同的库/表 通过RegisterDBAccessBuild实现数据访问 运行测试程序,结果输出为 上面代码通过自定义定位参数和定位规则,没有任何耦合,调用也很简单,完美达到了预期效果 测试代码地址:https://github.com/CRL2020/CRL.NetStandard/tree/master/Test/CRLCoreTest 在.net core中完美解决多租户分库分表的问题 标签:cti 问题 sql 返回 creat on() 如何 mss col 原文地址:https://www.cnblogs.com/hubro/p/12693868.htmlclass Program
{
static IServiceProvider provider;
static Program()
{
var services = new ServiceCollection();
services.AddCRL
public class DBLocationCreator : IDBLocationCreator
{
ISettingConfigBuilder _settingConfigBuilder;
public DBLocationCreator(ISettingConfigBuilder settingConfigBuilder)
{
_settingConfigBuilder = settingConfigBuilder;
}
public void Init()
{
//自定义定位
_settingConfigBuilder.RegisterLocation
上一篇:jsp在js里获取项目名
下一篇:PHP练习题——输出变量