Mybatis动态设置表名

有时在开发过程中java代码中的表名和数据库的表名并不是一致的,此时我们就需要动态的设置java代码中的表名。

实例如下:
原来的表名是user

/*** 动态设置表名,查询所有的用户信息
定义接口代码:
使用@Param()定义表名

 * @param tableName 
 * * @return */ 
 List<User> getAllUser(@Param("
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis 是一种流行的 Java 持久层框架,用于与数据库进行交互。在实际开发中,有时需要根据不同的条件动态拼接名。以下是使用 Mybatis 实现动态拼接名的方法。 首先,在 Mybatis 的 SQL 映射文件中,我们可以使用动态 SQL 来根据条件拼接名。例如,使用 `<choose>` 标签和 `<when>` 标签来判断条件,并根据条件拼接不同的名,如下所示: ```xml <select id="selectData" parameterType="Map" resultMap="resultMap"> SELECT * FROM <choose> <when test="tableName == 'table1'"> table1 </when> <when test="tableName == 'table2'"> table2 </when> <otherwise> table3 </otherwise> </choose> WHERE id = #{id} </select> ``` 这里的 `tableName` 是一个传递给 SQL 的参数,用于判断选择哪个名进行拼接。 接下来,在 Java 代码中,我们只需将正确的名传递给 Mybatis 的 SQL 语句执行方法。例如,使用 `<map>` 来包装参数,并将 `tableName` 参数传递给 SQL,如下所示: ```java Map<String, Object> paramMap = new HashMap<>(); paramMap.put("id", 1); paramMap.put("tableName", "table1"); List<Map<String, Object>> result = sqlSession.selectList("selectData", paramMap); ``` 在上述代码中,我们将 `tableName` 参数设置为 "table1",这样 Mybatis 就会动态拼接 `table1` 名,并执行相应的 SQL 查询。 通过以上方法,我们可以实现根据不同的条件动态拼接名。这在某些场景下非常实用,例如在多租户系统中,根据不同的租户拼接不同的名。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值