几种不常用的 MyBatis 写法

(1)使用 bind 处理复杂表达式


<bind name="pattern" value="'%' + keyword + '%'"/>
<select id="selectUsersByKeyword" resultType="User">
    SELECT * FROM users WHERE username LIKE #{pattern}
</select>

bind 标签帮助我们在 SQL 中进行表达式计算,减少了 Java 中的拼接操作,使 SQL 更加简洁

(2)复用 SQL 片段


<sql id="baseUserColumns">
    id, username, age, email
</sql>

<select id="selectUsers" resultType="User">
    SELECT <include refid="baseUserColumns"/> FROM users
</select>

复用 SQL 片段能够提升代码的可维护性,避免了 SQL 语句的重复编写。

(3)多数据源支持

@Configuration
public class MyBatisConfig {
    @Bean
    public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception {
        SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
        factoryBean.setDataSource(dataSource);
        return factoryBean.getObject();
    }
}

多数据源支持让我们能够更好地管理不同的数据源,适用于微服务架构和复杂数据需求的场景

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值