mybatis中BaseTypeHandler的使用

2023-11-05 15:36

本文主要是介绍mybatis中BaseTypeHandler的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mybatis中BaseTypeHandler的使用

自定义TypeHandler

package com.cdn.demo.handler;import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;/*** @author 蔡定努* @date 2023/11/04 16:51*/
public class StringTypeHandler<T> extends BaseTypeHandler<T> {@Overridepublic void setNonNullParameter(PreparedStatement preparedStatement, int i, T integer, JdbcType jdbcType) throws SQLException {preparedStatement.setObject(i, integer);}@Overridepublic T getNullableResult(ResultSet resultSet, String s) throws SQLException {System.out.println(resultSet.getObject(s));return (T) resultSet.getObject(s);}@Overridepublic T getNullableResult(ResultSet resultSet, int i) throws SQLException {return (T) resultSet.getObject(i);}@Overridepublic T getNullableResult(CallableStatement callableStatement, int i) throws SQLException {return (T) callableStatement.getObject(i);}
}

实体类

package com.cdn.demo.entity;import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import java.io.Serializable;import com.cdn.demo.handler.StringTypeHandler;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;/*** @author author* @since 2023-10-25*/
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName(value = "person",autoResultMap = true)
public class Person implements Serializable {private static final long serialVersionUID = 1L;@TableId(value = "id", type = IdType.AUTO)private Integer id;private Integer userId;@TableField(typeHandler = StringTypeHandler.class)private String job;private Integer age;}

Mapper

package com.cdn.demo.mapper;import com.cdn.demo.entity.Person;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.cdn.demo.handler.StringTypeHandler;
import org.apache.ibatis.annotations.*;import java.math.BigDecimal;
import java.util.List;/*** <p>*  Mapper 接口* </p>** @author author* @since 2023-10-25*/
public interface PersonMapper extends BaseMapper<Person> {@Select("select * from person where id = 1")@Results({@Result(property = "job", column = "job", javaType = BigDecimal.class, typeHandler = StringTypeHandler.class)})List<Person> person();List<Person> anno();}

XML

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.cdn.demo.mapper.PersonMapper"><!-- 通用查询映射结果 --><resultMap id="BaseResultMap" type="com.cdn.demo.entity.Person"><id column="id" property="id" /><result column="user_id" property="userId" /><result column="job" property="job" typeHandler="com.cdn.demo.handler.StringTypeHandler"/><result column="age" property="age" /></resultMap><!-- 通用查询结果列 --><sql id="Base_Column_List">id, user_id, job, age</sql><select id="anno" resultMap="BaseResultMap">select <include refid="Base_Column_List"/> from person where id =1</select></mapper>

Controller

package com.cdn.demo.controller;import cn.hutool.core.util.RandomUtil;
import com.cdn.demo.entity.Person;
import com.cdn.demo.mapper.PersonMapper;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.annotation.Resource;/*** <p>*  前端控制器* </p>** @author author* @since 2023-10-25*/
@RestController
@RequestMapping("/person")
public class PersonController {@Resourceprivate PersonMapper personMapper;/*** xml方式* @author 蔡定努*/@GetMapping("add")public void add() {Person person1 = new Person();person1.setUserId(0);person1.setJob(RandomUtil.randomString(3));person1.setAge(0);personMapper.insert(person1);}/*** xml的方式* @author 蔡定努*/@GetMapping("xml")public Object xml() {return personMapper.person();}/*** 注解的方式* @return*/@GetMapping("anno")public Object anno() {return personMapper.anno();}/*** plus的方式* @return*/@GetMapping("plus")public Object plus() {return personMapper.selectById(1);}}

这篇关于mybatis中BaseTypeHandler的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/350804

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

C#中lock关键字的使用小结

《C#中lock关键字的使用小结》在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块,下面就来介绍一下lock关键字的使用... 目录使用方式工作原理注意事项示例代码为什么不能lock值类型在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时