实体类里面调用DAO层

一、背景

  项目在启动的时候会把数据字典加载到redis中,实体类的字典名称通过get获得,这时候只有一个数据库。现在业务做了修改,后台是多数据源,字典加载到redis中只加载到了主库,如果从从库获取数据,从库的数据字典获取不到,所以我从实体类下手。

二:代码

 

工具类:

import com.spcp.qypt.aqjc.productionCell.mapper.SyncDatabaseSysDataMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

@Component
public class SyncDatabaseSysDataUtil {
private static SyncDatabaseSysDataMapper syncDatabaseSysDataMapper;

@Autowired
public void setApplicationContext(SyncDatabaseSysDataMapper syncDatabaseSysDataMapper){
SyncDatabaseSysDataUtil.syncDatabaseSysDataMapper=syncDatabaseSysDataMapper;
}

public static String getDataNameById(String id) {
String data = syncDatabaseSysDataMapper.getDataNameById(id);
return data == null ? "" : data;
}
}

DAO层:
import com.baomidou.dynamic.datasource.annotation.DS;
import org.apache.ibatis.annotations.Mapper;

@Mapper
@DS("database2")
public interface SyncDatabaseSysDataMapper {
String getDataNameById(String id);
}

三、总结

posted @   leocat  阅读(43)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示