1. 用两种方式在springboot项目中实现适配器模式

用两种方式在springboot项目中实现适配器模式

1. 场景

当我们后台有两个数据库,分别为mysql和oracle,根据前端参数中的数据库类型字段,去查询对应sql语句

2. 方式1,通过实现类定义类型字段实现

2.1 创建接口

public interface DbService {

    /**
     * 获取数据库类型
     * @return
     */
    String getDbType();

    /**
     * 查询数据库sql
     * @return
     */
    String getDbSql();
}

2.2 创建mysql实现类

@Service
public class MysqlDbService implements DbService{

    @Override
    public String getDbType() {
        return "mysql";
    }

    @Override
    public String getDbSql() {
        return "获取mysql的SQL";
    }
}

2.3 创建oracle实现类

@Service
public class OracleSDbService implements DbService{

    @Override
    public String getDbType() {
        return "oracle";
    }

    @Override
    public String getDbSql() {
        return "获取oracle的SQL";
    }
}

2.4 创建接口,在接口中注入service集合,根据每个实现类中定义的dbType进行匹配后进行调用

@RestController
@RequestMapping("/test")
public class TestController {

    @Resource
    private List<DbService> dbServiceList;

    @GetMapping("/getDbSql1")
    public String getDbSql(@RequestParam String dbtype){
        DbService dbService = dbServiceList.stream().filter(item -> dbtype.equals(item.getDbType())).findFirst().get();
        return dbService.getDbSql();
    }

}

2.5 测试,浏览器输入

在这里插入图片描述

3. 方式2,以动态service名称的方式实现

3.1 创建接口

public interface DbService {

    /**
     * 获取数据库类型
     * @return
     */
    String getDbType();

    /**
     * 查询数据库sql
     * @return
     */
    String getDbSql();
}

3.2 创建创建mysql实现类,定义实现类名称为mysqlDbService

@Service(value = "mysqlDbService")
public class MysqlDbService implements DbService{

    @Override
    public String getDbType() {
        return "mysql";
    }

    @Override
    public String getDbSql() {
        return "获取mysql的SQL";
    }
}

3.3 创建创建oracle实现类,定义实现类名称为oracleDbService

@Service(value = "oracleDbService")
public class OracleSDbService implements DbService{

    @Override
    public String getDbType() {
        return "oracle";
    }

    @Override
    public String getDbSql() {
        return "获取oracle的SQL";
    }
}

3.4 引入ApplicationContext,获取service方法名

@Component("applicationContextHelper")
public class ApplicationContextHelper implements ApplicationContextAware {

    private static ApplicationContext applicationContext;

    public static <T> T popBean(String name, Class<T> clazz) {
        if (applicationContext == null) {
            return null;
        }
        return applicationContext.getBean(name, clazz);
    }

    @Override
    public void setApplicationContext(ApplicationContext context) throws BeansException {
        applicationContext = context;
    }

    public ApplicationContext getInstance() {
        return applicationContext;
    }
}

3.5 调用接口,通过ApplicationContextHelper根据service名称动态获取实现类,调用方法

@RestController
@RequestMapping("/test")
public class TestController {

    @Resource
    private List<DbService> dbServiceList;

    @GetMapping("/getDbSql2")
    public String getDbSql2(@RequestParam String dbtype){
        DbService dbService = ApplicationContextHelper.popBean(dbtype + "DbService", DbService.class);
        return dbService.getDbSql();
    }
}

3.6 测试

在这里插入图片描述

相关推荐

  1. 创建springboot项目方式

    2024-03-14 06:06:04       17 阅读
  2. django实现适配器模式

    2024-03-14 06:06:04       28 阅读
  3. SpringBoot实现跨域的几方式

    2024-03-14 06:06:04       32 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-14 06:06:04       17 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-14 06:06:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-14 06:06:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-14 06:06:04       18 阅读

热门阅读

  1. Ubuntu22.04 MySQL8.0安装教程

    2024-03-14 06:06:04       22 阅读
  2. C#中的线程和Apartment状态

    2024-03-14 06:06:04       24 阅读
  3. 数字媒体专业AR增强现实仿真模拟实训

    2024-03-14 06:06:04       21 阅读
  4. 关于k8s中 storageclass 的 is-default-sc 默认存储设置

    2024-03-14 06:06:04       18 阅读
  5. k8s rancher开源平台(概念,部署示例,)

    2024-03-14 06:06:04       18 阅读
  6. k8s HPA 自动伸缩机制 (配置,资源限制,)

    2024-03-14 06:06:04       20 阅读
  7. Android 辅助功能 -抢红包

    2024-03-14 06:06:04       15 阅读
  8. C#+datax实现sql server数据同步到redis

    2024-03-14 06:06:04       16 阅读