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

文章目录

  • 用两种方式在springboot项目中实现适配器模式
    • [1. 场景](#1. 场景)
    • [2. 方式1,通过实现类定义类型字段实现](#2. 方式1,通过实现类定义类型字段实现)
      • [2.1 创建接口](#2.1 创建接口)
      • [2.2 创建mysql实现类](#2.2 创建mysql实现类)
      • [2.3 创建oracle实现类](#2.3 创建oracle实现类)
      • [2.4 创建接口,在接口中注入service集合,根据每个实现类中定义的dbType进行匹配后进行调用](#2.4 创建接口,在接口中注入service集合,根据每个实现类中定义的dbType进行匹配后进行调用)
      • [2.5 测试,浏览器输入](#2.5 测试,浏览器输入)
    • [3. 方式2,以动态service名称的方式实现](#3. 方式2,以动态service名称的方式实现)
      • [3.1 创建接口](#3.1 创建接口)
      • [3.2 创建创建mysql实现类,定义实现类名称为mysqlDbService](#3.2 创建创建mysql实现类,定义实现类名称为mysqlDbService)
      • [3.3 创建创建oracle实现类,定义实现类名称为oracleDbService](#3.3 创建创建oracle实现类,定义实现类名称为oracleDbService)
      • [3.4 引入ApplicationContext,获取service方法名](#3.4 引入ApplicationContext,获取service方法名)
      • [3.5 调用接口,通过ApplicationContextHelper根据service名称动态获取实现类,调用方法](#3.5 调用接口,通过ApplicationContextHelper根据service名称动态获取实现类,调用方法)
      • [3.6 测试](#3.6 测试)

用两种方式在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 分钟前
用虚拟IP扩容端口池:解决高并发WebSocket端口耗尽问题
前端·后端·websocket
知其然亦知其所以然9 分钟前
JVM社招面试题:队列和栈是什么?有什么区别?我在面试现场讲了个故事…
java·后端·面试
武子康12 分钟前
大数据-30 ZooKeeper Java-API 监听节点 创建、删除节点
大数据·后端·zookeeper
知了一笑13 分钟前
SpringBoot3集成多款主流大模型
spring boot·后端·openai
wmze15 分钟前
InnoDB存储引擎--索引与锁
后端
星辰大海的精灵18 分钟前
如何确保全球数据管道中的跨时区数据完整性和一致性
java·后端·架构
调试人生的显微镜20 分钟前
iOS App首次启动请求异常调试:一次冷启动链路抓包与初始化流程修复
后端
AI小智23 分钟前
Context Engineering:AI 工程的下一个前沿阵地?
后端
paopaokaka_luck23 分钟前
基于SpringBoot+Vue的酒类仓储管理系统
数据库·vue.js·spring boot·后端·小程序
梦兮林夕24 分钟前
02 gRPC 语法及类型介绍
后端·go·grpc