依星源码资源网,依星资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

【好消息,好消息,好消息】VIP会员可以发表文章赚积分啦 !
查看: 5|回复: 0

SpringBoot从配置文件里读取表名并将其应用于 @TableName 注解

[复制链接] 主动推送

1万

主题

1万

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
14135
发表于 9 小时前 | 显示全部楼层 |阅读模式
SpringBoot从配置文件里读取表名并将其应用于 @TableName 注解
若要从配置文件里读取表名并将其应用于 `@TableName` 注解,可借助 Spring Boot 的配置属性注入功能达成。下面是具体的实现步骤与代码示例:

### 1. 在配置文件中定义表名
在 `application.properties` 或者 `application.yml` 文件里定义表名。

#### `application.properties`
```properties
mybatis-plus.table-name=fwd_files
```

#### `application.yml`
```yaml
mybatis-plus:
  table-name: fwd_files
```

### 2. 创建配置类来读取配置
创建一个配置类,借助 `@ConfigurationProperties` 注解读取配置文件中的表名。

```java:d:\projects\VSCODE_PRO\web\she\src\main\java\com\example\config\MyBatisPlusConfigProperties.java
package com.example.config;

import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

@Component
@ConfigurationProperties(prefix = "mybatis-plus")
public class MyBatisPlusConfigProperties {
    private String tableName;

    public String getTableName() {
        return tableName;
    }

    public void setTableName(String tableName) {
        this.tableName = tableName;
    }
}
```

### 3. 使用配置类中的表名
在实体类里注入配置类,并且使用读取到的表名。

```java:d:\projects\VSCODE_PRO\web\she\src\main\java\com\example\entity\FWDFiles.java
package com.example.entity;

import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.extension.activerecord.Model;
import com.example.config.MyBatisPlusConfigProperties;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

// ... existing code ...
@Component
public class FWDFiles extends Model<FWDFiles> {
    private static String TABLE_NAME;

    @Autowired
    public FWDFiles(MyBatisPlusConfigProperties configProperties) {
        TABLE_NAME = configProperties.getTableName();
    }

    public static String getTableName() {
        return TABLE_NAME;
    }

    @TableName(value = "${mybatis-plus.table-name}") // 从配置文件读取表名
    // 实体类字段定义...
}
```

### 4. 确保配置类被扫描
要保证配置类被 Spring Boot 扫描到,可以在主应用类上添加 `@EnableConfigurationProperties` 注解。

```java:d:\projects\VSCODE_PRO\web\she\src\main\java\com\example\YourApplication.java
package com.example;

import com.example.config.MyBatisPlusConfigProperties;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.properties.EnableConfigurationProperties;

@SpringBootApplication
@EnableConfigurationProperties(MyBatisPlusConfigProperties.class)
public class YourApplication {
    public static void main(String[] args) {
        SpringApplication.run(YourApplication.class, args);
    }
}
```

### 代码解释
- **配置文件**:在 `application.properties` 或者 `application.yml` 中定义表名。
- **配置类**:`MyBatisPlusConfigProperties` 类借助 `@ConfigurationProperties` 注解读取配置文件中的表名。
- **实体类**:在 `FWDFiles` 类中注入 `MyBatisPlusConfigProperties` 类,并且使用读取到的表名。
- **主应用类**:在主应用类上添加 `@EnableConfigurationProperties` 注解,确保配置类被扫描到。

通过以上步骤,你就能从配置文件中读取表名并将其应用于 `@TableName` 注解。



如何在MyBatis-Plus中使用@TableName注解从配置文件中读取表名。首先,我需要确认用户的具体需求。他们希望动态配置表名,而不是硬编码在代码里。

接下来,我得回忆一下MyBatis-Plus的相关知识。记得@TableName有一个value属性,通常用来指定表名,但用户想让它从配置文件读取。这时候应该使用EL表达式,比如${}来引用配置文件中的属性。

然后,需要考虑配置文件的格式,比如application.yml或application.properties。用户需要在配置文件中定义表名的属性,例如mybatis-plus.table-name=fwd_files,然后在注解中使用@TableName("${mybatis-plus.table-name}")。

还要检查是否正确配置了MyBatis-Plus的全局配置,确保它能够正确解析占位符。可能需要确认是否添加了@Configuration注解的配置类,或者是否有其他必要的设置。

最后,确保用户了解这种动态配置的好处,比如不同环境切换表名,而不需要修改代码。同时提醒他们如果遇到问题,可以检查配置文件是否正确加载,或者是否有拼写错误。


另外一种方法:

要实现通过配置文件动态设置MyBatis-Plus实体类表名,可以在@TableName注解中使用SPEL表达式读取配置参数。具体步骤:1. 在application.yml中配置表名参数如mybatis-plus.table-name;2. 实体类注解改为@TableName("${mybatis-plus.table-name}");3. 确保MyBatis-Plus配置类开启占位符解析功能。

根据解决方案,需要修改实体类的@TableName注解使用SPEL表达式读取配置文件。首先定位到FWDFiles实体类文件,将硬编码的表名改为${mybatis-plus.table-name}表达式。

  1. package com.example.entity;

  2. import com.baomidou.mybatisplus.annotation.TableName;
  3. import com.baomidou.mybatisplus.extension.activerecord.Model;

  4. @TableName(value = "${mybatis-plus.table-name}") // 从配置文件读取表名
  5. public class FWDFiles extends Model<FWDFiles> {
  6.     // 实体类字段定义...
  7. }
复制代码
现在需要创建配置文件并添加表名配置项,使MyBatis-Plus能够正确读取配置。将在resources目录下创建application.yml并设置mybatis-plus.table-name参数。
  1. mybatis-plus:
  2.   table-name: fwd_files
  3.   configuration:
  4.     log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
复制代码
已实现通过配置文件动态设置MyBatis-Plus实体类表名功能,主要修改内容如下:

1. 创建实体类文件 :在`src/main/java/com/example/entity/` 路径下新建FWDFiles.java,使用`@TableName("${mybatis-plus.table-name}")` 注解实现配置读取
2. 添加配置文件 :在resources目录下创建application.yml,配置`mybatis-plus.table-name: fwd_files` 参数
3. 配置占位符解析 :需在MyBatis-Plus配置类中添加`@Configuration` 和属性解析器配置(需确保项目已存在相关配置类)
后续如需修改表名,只需在yml配置文件中修改对应参数值即可生效。

相关帖子

扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员6折;永久VIP4折
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

免责声明:
1、本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
2、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,请勿任何商业目的与商业用途。
3、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4、论坛的所有内容都不保证其准确性,完整性,有效性,由于源码具有复制性,一经售出,概不退换。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
5、用户使用本网站必须遵守适用的法律法规,对于用户违法使用本站非法运营而引起的一切责任,由用户自行承担
6、本站所有资源来自互联网转载,版权归原著所有,用户访问和使用本站的条件是必须接受本站“免责声明”,如果不遵守,请勿访问或使用本网站
7、本站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本站不承担任何责任。
8、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。
9、本站以《2013 中华人民共和国计算机软件保护条例》第二章 “软件著作权” 第十七条为原则:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。若有学员需要商用本站资源,请务必联系版权方购买正版授权!
10、本网站如无意中侵犯了某个企业或个人的知识产权,请来信【站长信箱312337667@qq.com】告之,本站将立即删除。
郑重声明:
本站所有资源仅供用户本地电脑学习源代码的内含设计思想和原理,禁止任何其他用途!
本站所有资源、教程来自互联网转载,仅供学习交流,不得商业运营资源,不确保资源完整性,图片和资源仅供参考,不提供任何技术服务。
本站资源仅供本地编辑研究学习参考,禁止未经资源商正版授权参与任何商业行为,违法行为!如需商业请购买各资源商正版授权
本站仅收集资源,提供用户自学研究使用,本站不存在私自接受协助用户架设游戏或资源,非法运营资源行为。
 
在线客服
点击这里给我发消息 点击这里给我发消息 点击这里给我发消息
售前咨询热线
312337667

微信扫一扫,私享最新原创实用干货

QQ|免责声明|小黑屋|依星资源网 ( 鲁ICP备2021043233号-3 )|网站地图

GMT+8, 2025-3-12 19:03

Powered by Net188.com X3.4

邮箱:312337667@qq.com 客服QQ:312337667(工作时间:9:00~21:00)

快速回复 返回顶部 返回列表