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

相关文章

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

Golang使用etcd构建分布式锁的示例分享

《Golang使用etcd构建分布式锁的示例分享》在本教程中,我们将学习如何使用Go和etcd构建分布式锁系统,分布式锁系统对于管理对分布式系统中共享资源的并发访问至关重要,它有助于维护一致性,防止竞... 目录引言环境准备新建Go项目实现加锁和解锁功能测试分布式锁重构实现失败重试总结引言我们将使用Go作

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服

Python3中Sanic中间件的使用

《Python3中Sanic中间件的使用》Sanic框架中的中间件是一种强大的工具,本文就来介绍Python3中Sanic中间件的使用,具有一定的参考价值,感兴趣的可以了解一下... 目录Sanic 中间件的工作流程中间件的使用1. 全局中间件2. 路由中间件3. 异常处理中间件4. 异步中间件5. 优先级