千里马平台设计说明-获取基础数据

千里马平台采用分布式数据库(指大平台模式),各业务使用各自的数据库,例如客户关系管理使用数据库zcrm_core,财务系统使用zfms_core,各业务后台程序只联各自业务库,完成各自领域内的事务。机构、人员这些核心数据存储在qlm_core中。业务数据存储机构、人员时只存储对应ID。需要获取具体信息时,前台可以通过id访问对应基础数据服务即可,但是后端想要获取具体数据就需要分成两种情况:

       基础数据在本业务链接的数据库中(包括基础服务本身、采用紧凑模式时各业务后台);基础数据不在本业务链接的数据库中。实际编程时要一套代码适应多种模式,平台采用的方式是统一API模式。

public class HRAPI {
@Autowired
private OrgInfoService orgInfoService;
@Autowired
private PersonInfoService personInfoService;
@Autowired
private HRFeignClient hrFeignClient;

public OrgInfoDto findOrgBasicInfoById(String orgID){
    if ("local".equals(QLMContants.HRSource)){
        OrgBasicInfo org=this.orgInfoService.findOrgBasicInfoById(orgID);
        if (org!=null){
            return org.toOrgInfoDto();
        }
        else{
            return null;
        }
    }
    else{
        RequestInfo req=new RequestInfo();
        req.init();
        req.setTag(orgID);
        ResponseResult<OrgInfoDto> result= hrFeignClient.findOrgBasicInfoById(req);
        if (result!=null && result.isSuccess()){
            return result.getData();
        }
        else{
            if (result!=null){
                CommonsUtil.recordLog("HRAPI.findOrgBasicInfoById msg="+result.getMsg());
            }
            return null;
        }
    }
}

通过qlm.HRSource配置为local 还是 server来区分具体情况。另本地实现、远程feign实现中都要实现先取缓存再取数据库的逻辑。​​​​

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-18 17:48:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-18 17:48:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-18 17:48:01       87 阅读
  4. Python语言-面向对象

    2024-02-18 17:48:01       96 阅读

热门阅读

  1. go-zero读取mysql部分字段

    2024-02-18 17:48:01       48 阅读
  2. 二分查找算法

    2024-02-18 17:48:01       50 阅读
  3. 【字符串】AC自动机

    2024-02-18 17:48:01       56 阅读
  4. 作业day6

    2024-02-18 17:48:01       46 阅读
  5. vivado FIR Filters

    2024-02-18 17:48:01       47 阅读
  6. 小程序API能力汇总——基础容器API(二)

    2024-02-18 17:48:01       41 阅读
  7. Z4.3 求最大公约数和最小公倍数。

    2024-02-18 17:48:01       46 阅读
  8. [AIGC] Kafka 消费者的实现原理

    2024-02-18 17:48:01       50 阅读