发现MyBatis的独特用法
随着Java开发的不断演进,MyBatis作为一款经典的ORM框架,也在不断地更新和优化。除了常见的基本使用方式外,MyBatis还提供了一些非典型的写法,能够更加灵活和高效地使用它。本文将探索一些非典型的MyBatis写法,并提供具体的代码示例。
- 动态SQL的灵活运用
动态SQL是MyBatis的一大特色,可以根据不同的条件自动生成不同的SQL语句。常见的用法有使用动态标签<if></if>
、<choose></choose>
、<when></when>
、<otherwise></otherwise>
、<trim></trim>
、<foreach></foreach>
等,但在某些情况下,传统的动态SQL写法可能不够灵活。这时可以使用MyBatis提供的<bind></bind>
标签,将查询条件和SQL拼接成一个变量,再通过where
关键字来组装条件语句。<if></if>
、<choose></choose>
、<when></when>
、<otherwise></otherwise>
、<trim></trim>
、<foreach></foreach>
等,但在某些情况下,传统的动态SQL写法可能不够灵活。这时可以使用MyBatis提供的<bind></bind>
标签,将查询条件和SQL拼接成一个变量,再通过where
关键字来组装条件语句。
<select id="getUserList" resultType="User"> <bind name="where" value=""> <if test="name != null"> <bind name="where" value="${where} AND name = #{name}" /> </if> <if test="age != null"> <bind name="where" value="${where} AND age = #{age}" /> </if> </bind> SELECT * FROM user WHERE 1=1 <where>${where}</where> </select>
通过使用<bind></bind>
标签,我们可以更加方便地拼接不同的查询条件,减少重复的代码。同时,使用<where></where>
标签可以在没有任何查询条件时自动去除where
关键字。
- 自定义类型处理器
MyBatis默认提供了一些常见的类型处理器,用于将Java对象和数据库字段相互转化。但在实际应用中,我们可能会遇到一些不常见的数据类型,这时就需要自定义类型处理器来处理这些数据类型。自定义类型处理器可以继承org.apache.ibatis.type.BaseTypeHandler
或实现org.apache.ibatis.type.TypeHandler
接口。除了处理不常见的数据类型外,我们还可以通过自定义类型处理器来处理特殊的数据转换需求,如将数据库中的数字字段转化为枚举类型。
public class EnumTypeHandler<E extends Enum<E>> extends BaseTypeHandler<E> { private Class<E> type; public EnumTypeHandler(Class<E> type) { if (type == null) { throw new IllegalArgumentException("Type argument cannot be null"); } this.type = type; } @Override public void setNonNullParameter(PreparedStatement ps, int i, E parameter, JdbcType jdbcType) throws SQLException { ps.setInt(i, parameter.ordinal()); } @Override public E getNullableResult(ResultSet rs, String columnName) throws SQLException { int ordinal = rs.getInt(columnName); return rs.wasNull() ? null : convert(ordinal); } private E convert(int ordinal) { E[] enums = type.getEnumConstants(); for (E e : enums) { if (e.ordinal() == ordinal) { return e; } } return null; } }
通过自定义类型处理器,我们可以根据实际需求,灵活地处理不同的数据类型转换逻辑,使得处理复杂数据更加简单高效。
- 使用注解简化映射配置
传统的MyBatis映射配置需要通过XML文件来配置,但MyBatis也提供了注解来简化映射配置的过程。通过使用注解,我们可以直接在实体类上进行映射配置,而不需要再编写大量的XML配置文件。
public interface UserMapper { @Select("SELECT * FROM user WHERE id = #{id}") User getUserById(int id); @Insert("INSERT INTO user(name, age) VALUES(#{name}, #{age})") @Options(useGeneratedKeys = true, keyProperty = "id") int insertUser(User user); @Delete("DELETE FROM user WHERE id = #{id}") int deleteUser(int id); @Update("UPDATE user SET name = #{name}, age = #{age} WHERE id = #{id}") int updateUser(User user); }
通过在方法上添加对应的注解,我们可以直接进行SQL语句的编写,避免了繁琐的XML配置文件。同时,通过使用@Options
rrreee
<bind></bind>
标签,我们可以更加方便地拼接不同的查询条件,减少重复的代码。同时,使用<where></where>
标签可以在没有任何查询条件时自动去除where
关键字。
- 自定义类型处理器
MyBatis默认提供了一些常见的类型处理器,用于将Java对象和数据库字段相互转化。但在实际应用中,我们可能会遇到一些不常见的数据类型,这时就需要自定义类型处理器来处理这些数据类型。自定义类型处理器可以继承org.apache.ibatis.type.BaseTypeHandler
或实现org.apache.ibatis.type.TypeHandler
接口。除了处理不常见的数据类型外,我们还可以通过自定义类型处理器来处理特殊的数据转换需求,如将数据库中的数字字段转化为枚举类型。
- 🎜使用注解简化映射配置🎜🎜🎜传统的MyBatis映射配置需要通过XML文件来配置,但MyBatis也提供了注解来简化映射配置的过程。通过使用注解,我们可以直接在实体类上进行映射配置,而不需要再编写大量的XML配置文件。🎜rrreee🎜通过在方法上添加对应的注解,我们可以直接进行SQL语句的编写,避免了繁琐的XML配置文件。同时,通过使用
@Options
注解,我们还可以指定自动生成主键的方式。🎜🎜总结:🎜🎜MyBatis作为一款优秀的ORM框架,不仅提供了常见的使用方式,还有一些非典型的写法,能够更加灵活和高效地使用它。本文探索了动态SQL的灵活运用、自定义类型处理器和使用注解简化映射配置三个非典型的MyBatis写法,并提供了具体的代码示例。通过充分发挥MyBatis的特性,我们能够更好地应对实际开发中的需求,提升开发效率和代码质量。🎜🎜(注:本文仅为发现MyBatis的独特用法,具体的代码示例仅供参考,开发者在实际应用中需要根据具体需求进行适当调整。)🎜以上是发现MyBatis的独特用法的详细内容。更多信息请关注PHP中文网其他相关文章!

缓存的概述和分类概述缓存就是一块内存空间.保存临时数据为什么使用缓存将数据源(数据库或者文件)中的数据读取出来存放到缓存中,再次获取的时候,直接从缓存中获取,可以减少和数据库交互的次数,这样可以提升程序的性能!缓存的适用情况适用于缓存的:经常查询但不经常修改的(eg:省市,类别数据),数据的正确与否对最终结果影响不大的不适用缓存的:经常改变的数据,敏感数据(例如:股市的牌价,银行的汇率,银行卡里面的钱)等等MyBatis缓存类别一级缓存:它是sqlSession对象的缓存,自带的(不需要配置)不

MyBatis允许使用插件来拦截的方法Executor(update,query,flushStatements,commit,rollback,getTransaction,close,isClosed)ParameterHandler(getParameterObject,setParameters)ResultSetHandler(handleResultSets,handleOutputParameters)StatementHandler(prepare,parameterize,ba

mybatis分页的方式:1、借助数组进行分页,首先查询出全部数据,然后再list中截取需要的部分。2、借助Sql语句进行分页,在sql语句后面添加limit分页语句即可。3、利用拦截器分页,通过拦截器给sql语句末尾加上limit语句来分页查询。4、利用RowBounds实现分页,需要一次获取所有符合条件的数据,然后在内存中对大数据进行操作即可实现分页效果。

简介今天开发时想将自己写好的代码拿来优化,因为不想在开发服弄,怕搞坏了到时候GIT到生产服一大堆问题,然后把它分离到我轮子(工具)项目上,最后运行后发现我获取List的时候很卡至少10秒,我惊了平时也就我的正常版本是800ms左右(不要看它很久,因为数据量很大,也很正常。),前提是我也知道很慢,就等的确需要优化时,我在放出我优化的plus版本,回到10秒哪里,最开始我刚刚接到这个app项目时,在我用PageHelper.startPage(page,num);(分页),还没等查到的数据封装(Pa

mybatis调用mysql存储过程并获取返回值1、mysql创建存储过程#结束符号默认;,delimiter$$语句表示结束符号变更为$$delimiter$$CREATEPROCEDURE`demo`(INinStrVARCHAR(100),outourStrVARCHAR(4000))BEGINSETourStr='01';if(inStr=='02')thensetourStr='02';en

当某些sql因为不知名原因堵塞时,为了不影响后台服务运行,想要给sql增加执行时间限制,超时后就抛异常,保证后台线程不会因为sql堵塞而堵塞。一、yml全局配置单数据源可以,多数据源时会失效二、java配置类配置成功抛出超时异常。importcom.alibaba.druid.pool.DruidDataSource;importcom.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;importorg.apache.

一、springboot与mybatis的配置1.首先,springboot配置mybatis需要的全部依赖如下:org.springframework.bootspring-boot-starter-parent1.5.1.RELEASEorg.springframework.bootspring-boot-starter-web1.5.1.RELEASEorg.mybatis.spring.bootmybatis-spring-boot-starter1.2.0com.oracleojdbc

一、思路将分页所需的内容都放到一个实体类中分页数据所需要的实体类!内包含页码,页大小,总条数,总页数,起始行pagehelpr提供了这个类pageInfo,不需要我们自己创建二、主要逻辑select*from表名limit起始行,展示几条数据#第n页每页展示五条数据select*from表名limit(n-1)*5,5#每页展示多少条pageSize3#总共有多少条totalselectcount(*)from表名#总页数pagespages=total%pagesSize==0?total/p


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

禅工作室 13.0.1
功能强大的PHP集成开发环境