Spring boot + Mybatis Plus DatabaseId的使用

Spring boot + Mybatis Plus DatabaseId的使用

Mybatis中使用DatabaseId

Mybatis中如果需要对DatabaseId进行支持需要在配置 mybatis-config.xml 中加入如下配置

<databaseIdProvider type="DB_VENDOR">
  <property name="MySQL" value="mysql"/>        
  <property name="Oracle" value="oracle" />
</databaseIdProvider>

加入这段配置所我们就可以在mapper.xml中这么使用了

<select id="selectAll" resultType="com.alen.trial.multilds.model.Multil" databaseId="mysql">
     select * from multil
</select>
<select id="selectAll" resultType="com.alen.trial.multilds.model.Multil" databaseId="oracle">
       select id from multil
</select>

那么在Mybatis plus中应该怎么用呢?

经过分析以上代码可知,Mybatis中提供一个接口DatabaseIdProvider来做数据库类型和sql中DatabaseId的映射,Mybatis通过上面的配置文件创建了一个实现DatabaseIdProvider的类并载入了映射配置,知道这一点就好办了,我们只需要提供一个同样的DatabaseIdProvider 实现类到Spring容器中应该就可以了,于是我在我的项目中加入了以下代码:

   /**
   为了配置管理我把这段代码加入到了 MybatisPlusConfig 中
   */
    @Bean
    public DatabaseIdProvider databaseIdProvider() {
        VendorDatabaseIdProvider databaseIdProvider = new VendorDatabaseIdProvider();
        Properties properties = new Properties();
        properties.put("Oracle","oracle");
        properties.put("MySQL","mysql");
        databaseIdProvider.setProperties(properties);
        return databaseIdProvider;
    }

在application.yml中加入(这一步不是必须的,Mybatis会根据配置的数据源来判断数据库类型从而来选择使用哪个sql语句)

mybatis-plus:
  mapper-locations: classpath*:com/alen/trial/multilds/dao/*.xml
  global-config:
    db-config:
#      db-type: mysql
      db-type: oracle

测试结果

首先使用oracle测试(注意这里的数据源要修改成oracle的数据源)

为了方便测试加入了以下接口

    @GetMapping("/select/all")
    public List<Multil> getDataFormMysqlA() {
        return service.select();
    }

查询databaseId为oracle的

使用mysql测试

查询databaseId为mysql的

对比一下配置

<select id="selectAll" resultType="com.alen.trial.multilds.model.Multil" databaseId="mysql">
     select * from multil
</select>
<select id="selectAll" resultType="com.alen.trial.multilds.model.Multil" databaseId="oracle">
       select id from multil
</select>

没有问题,就是乱码了有点小瑕疵!

  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
好的,以下是基于 Spring BootMyBatis-Plus、Thymeleaf 和 Bootstrap 的留言板的实现步骤: 1. 创建 Spring Boot 项目 在 IDEA 中创建一个 Spring Boot 项目,选择 Web 和 Thymeleaf 作为依赖。 2. 添加 MyBatis-Plus 依赖 在 pom.xml 文件中添加 MyBatis-Plus 依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency> ``` 3. 创建留言板数据表 在 MySQL 中创建一个名为 message_board 的数据表,包含以下字段: ```sql CREATE TABLE `message_board` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL COMMENT '留言人姓名', `email` varchar(50) NOT NULL COMMENT '留言人邮箱', `content` varchar(255) NOT NULL COMMENT '留言内容', `create_time` datetime NOT NULL COMMENT '创建时间', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='留言板'; ``` 4. 创建 MyBatis-Plus 实体类和 Mapper 使用 MyBatis-Plus 的代码生成器,生成 Message 实体类和 MessageMapper 接口。 5. 编写 Service 层 创建 MessageService 接口和 MessageServiceImpl 实现类,其中 MessageServiceImpl 实现类注入 MessageMapper,实现增删改查等方法。 6. 编写 Controller 层 创建 MessageController 类,其中注入 MessageService,实现留言板的展示、添加留言和删除留言等功能。 7. 编写 Thymeleaf 页面 在 templates 目录下创建 message.html 页面,使用 Thymeleaf 和 Bootstrap 实现留言板的展示和添加留言的表单。 8. 运行项目 使用 IDEA 运行项目,在浏览器中访问 http://localhost:8080/message 即可看到留言板页面。 以上就是基于 Spring BootMyBatis-Plus、Thymeleaf 和 Bootstrap 的留言板的实现步骤,你可以参考这些步骤来实现自己的留言板。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值