MyBatis 写法

MyBatis 高效使用技巧

常见 MyBatis 使用技巧,这些技巧有助于简化数据库操作,提高开发效率,并增强系统的性能。

1. 动态 SQL

动态 SQL 让开发者能够依据参数灵活地构建 SQL 语句,避免了手动拼接字符串带来的复杂性和错误风险。

xml 复制代码
<select id="selectUsersByCondition" parameterType="map" resultType="User">
    SELECT * FROM users WHERE 1=1
    <if test="username != null">AND username = #{username}</if>
    <if test="age != null">AND age = #{age}</if>
    <if test="status != null">AND status = #{status}</if>
</select>
2. 批量操作

通过 <foreach> 标签可以轻松实现批量插入或更新,减少多次调用造成的性能损失。

xml 复制代码
<insert id="batchInsert" parameterType="list">
    INSERT INTO users (username, age)
    VALUES
    <foreach collection="list" item="user" separator=",">
        (#{user.username}, #{user.age})
    </foreach>
</insert>
3. 结果集映射 (resultMap)

当查询结果与实体类字段不匹配时,resultMap 可以帮助进行精确映射,适用于复杂的关联关系。

xml 复制代码
<resultMap id="userResultMap" type="User">
    <id property="id" column="user_id"/>
    <result property="username" column="user_name"/>
    <result property="age" column="user_age"/>
</resultMap>
4. 分页查询

利用分页插件(如 MyBatis-Plus 或 PageHelper)简化分页逻辑,无需手动处理 LIMITOFFSET

java 复制代码
Page<User> page = new Page<>(1, 10); // 第一页,每页10条记录
List<User> users = userMapper.selectPage(page, new QueryWrapper<>());
5. 一对多关系映射

collection 标签用于处理一对多的关系,自动将子表数据封装到父对象中。

xml 复制代码
<resultMap id="userWithOrders" type="User">
    <!-- 省略主表映射 -->
    <collection property="orders" ofType="Order">
        <id property="id" column="order_id"/>
        <result property="amount" column="order_amount"/>
    </collection>
</resultMap>
6. 注解与 XML 配合使用

结合 @Mapper 注解和 XML 映射文件,既保持了接口配置的简洁性,又实现了 SQL 的外部化管理。

java 复制代码
@Mapper
public interface UserMapper {
    List<User> selectUsersByCondition(Map<String, Object> params);
}
7. 批量更新

同样可以通过 <foreach> 实现批量更新,减少数据库交互次数。

xml 复制代码
<update id="batchUpdateUsers" parameterType="list">
    <foreach collection="list" item="user" separator=";">
        UPDATE users SET username = #{user.username}, age = #{user.age} WHERE id = #{user.id}
    </foreach>
</update>
8. 复杂表达式处理

bind 标签允许在 SQL 中直接处理复杂的表达式,使代码更整洁。

xml 复制代码
<bind name="pattern" value="'%' + keyword + '%'"/>
<select id="selectUsersByKeyword" resultType="User">
    SELECT * FROM users WHERE username LIKE #{pattern}
</select>
9. 自定义类型处理器

为了解决 Java 类型与数据库类型的不一致问题,可以创建自定义类型处理器。

java 复制代码
@MappedJdbcTypes(JdbcType.VARCHAR)
@MappedTypes(CustomType.class)
public class CustomTypeHandler extends BaseTypeHandler<CustomType> { /* ... */ }
10. 逻辑删除

逻辑删除是一种保留历史数据的删除方式,它只是标记记录为已删除状态。

xml 复制代码
<update id="deleteUser" parameterType="int">
    UPDATE users SET deleted = 1 WHERE id = #{id}
</update>
11. 分表策略

对于海量数据场景,分表策略能显著提升查询性能。注意防范 SQL 注入风险。

xml 复制代码
<select id="selectFromTable" resultType="User">
    SELECT * FROM ${tableName} WHERE id = #{id}
</select>
12. SQL 片段复用

使用 <sql> 标签定义可复用的 SQL 片段,减少重复代码。

xml 复制代码
<sql id="baseUserColumns">
    id, username, age, email
</sql>
13. 枚举类型映射

枚举类型处理器简化了枚举值与数据库字段间的映射,增强了代码的可读性。

java 复制代码
@EnumTypeHandler(EnumTypeHandler.class)
public enum UserStatus {
    ACTIVE, INACTIVE;
}
14. 多数据源配置

多数据源配置有助于分离不同类型的数据,满足微服务架构下的需求。

java 复制代码
@Configuration
public class MyBatisConfig {
    @Bean
    public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception {
        SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
        factoryBean.setDataSource(dataSource);
        return factoryBean.getObject();
    }
}
15. 延迟加载

延迟加载特性可以在需要时才加载关联数据,从而优化性能。

xml 复制代码
<settings>
    <setting name="lazyLoadingEnabled" value="true"/>
</settings>

相关推荐
小句11 小时前
Redis 基本数据类型及其适用场景与案例
redis·spring·mybatis
茶本无香13 小时前
Spring Boot 与 MyBatis 数据库操作
数据库·spring boot·mybatis
茂桑13 小时前
Mybatis的一级、二级缓存
java·spring·mybatis
quo-te2 天前
【JavaWeb学习Day19】
java·spring·maven·mybatis
安清h2 天前
【基于SprintBoot+Mybatis+Mysql】电脑商城项目之加入购物车和显示购物车列表
数据库·后端·mysql·spring·mybatis
帅的飞起来2 天前
倒排索引(Inverted Index)
数据库·oracle·mybatis
B站计算机毕业设计超人2 天前
计算机毕业设计SpringBoot+Vue.jst网上超市系统(源码+LW文档+PPT+讲解)
vue.js·spring boot·后端·eclipse·intellij-idea·mybatis·课程设计
菲力蒲LY3 天前
输入搜索、分组展示选项、下拉选取,全局跳转页,el-select 实现 —— 后端数据处理代码,抛砖引玉展思路
java·前端·mybatis
五月茶3 天前
Maven+SSM+SpringBoot+Mybatis-Plus
spring boot·maven·mybatis