博客
关于我
Mybatis老手复习文档
阅读量:443 次
发布时间:2019-03-06

本文共 2943 字,大约阅读时间需要 9 分钟。

MyBatis学习笔记

初识MyBatis

学习MyBatis是每个开发者都必须经历的阶段。虽然我之前在学习JPA+Hibernate时已经积累了一定的经验,但此次重新接触MyBatis让我对持久层框架有了更深入的理解。

MyBatis的优势

  • 灵活性:MyBatis在动态SQL方面的表现尤为突出,能够处理各种复杂的业务逻辑,极大地提升了代码的灵活性。
  • 效率:虽然有人认为MyBatis的效率不如JPA,但通过合理的配置和使用技巧,MyBatis在特定场景下表现依然出色。

MyBatis的开始

配置文件mybatis-config.xml

简单的MyBatis例子

package com.pipihao.pojo;import lombok.Data;import lombok.NoArgsConstructor;import java.io.Serializable;import java.util.Date;@Data@NoArgsConstructor@AllArgsConstructorpublic class Blog implements Serializable {    private String id;    private String title;    private String author;    private Date createTime;    private int view;}

配置映射

在MyBatis中,字段名与数据库字段名的命名差异通常会通过配置来解决。例如,数据库中的create_time可以映射到Java类中的createTime

日志配置

分页配置

MyBatis支持两种分页方式:原生分页和RowBunds分页。对于原生分页,直接在SQL中使用LIMITOFFSET即可。

RowBunds分页通过在Mapper接口中传递RowBunds对象来实现。

RowBounds rowBounds = new RowBounds(0, 2);List
blogs = mapper.findBlogById(rowBounds);

注解开发

在MyBatis中,注解开发可以与XML配置相结合,提供更灵活的开发体验。

public interface StudentMapper {    @Select("select * from student where id = #{sid}")    Students getStudentById(@Param("sid") int sid);}

多对一和一对多处理

多对一

一对多

动态SQL

动态SQL在MyBatis中通过<sql>标签实现,支持iftrimforeach等功能。

insert into blog (id,title,author,create_time,view) values (#{id},#{title},#{author},#{createTime},#{view})
and title = #{title}
and author = #{author}
update blog
title = #{title}
author = #{author}
where id = #{id}

缓存

MyBatis支持一级缓存和二级缓存。

一级缓存

默认启用,仅在一个SqlSession中有效。

二级缓存

通过@Cache注解或 <cache>标签实现。

总结

MyBatis作为一个灵活且强大的持久层框架,在动态SQL、缓存等方面表现出色。虽然JPA+Hibernate在对象关系映射方面更为强大,但MyBatis在小型项目中依然是一个不错的选择。

在实际开发中,建议结合PageHelper等工具来提升分页性能,并合理使用注解开发与XML配置相结合的方式,以提升开发效率。

转载地址:http://wfkfz.baihongyu.com/

你可能感兴趣的文章
oracle 定义双重循环例子
查看>>
ORACLE 客户端工具连接oracle 12504
查看>>
Oracle 客户端连接时报ORA-01019错误总结
查看>>
oracle 嵌套表 例子,Oracle之嵌套表(了解)
查看>>
Oracle 常用命令
查看>>
Oracle 常用的V$视图脚本(二)
查看>>
Oracle 并行原理与示例总结
查看>>
oracle 并集 时间_Oracle集合运算符 交集 并集 差集
查看>>
Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
查看>>
oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
查看>>
oracle 批量生成建同义词语句和付权语句
查看>>
oracle 抓包工具,shell 安装oracle和pfring(抓包) 及自动环境配置
查看>>
Oracle 拆分以逗号分隔的字符串为多行数据
查看>>
Oracle 排序中使用nulls first 或者nulls last 语法
查看>>
oracle 插入date日期类型的数据、插入从表中查出的数据,使用表中的默认数据
查看>>
Oracle 操作笔记
查看>>
oracle 数据库 安装 和优化
查看>>
oracle 数据库dg搭建规范1
查看>>
Oracle 数据库常用SQL语句(1)
查看>>
Oracle 数据库特殊查询总结
查看>>