Mybatis类型转换器

首先明白什么时候用到它,当数据库的字段类型和java字段类型无法默认匹配时候进行转换,比如现在数据库类型是INTEGER,而java当中类型是Boolean,true表示1,false表示0,这时候你在执行sql语句插入或者查询获取结果集时,类型就会出现不匹配的情况,这时候我们只需要书写一个类型转换器,并进行配置,之后java遇到INTEGER---Boolean两个类型的时候,就会帮我们自动转换,相当于你插入数据库的值传的是true,他就会转换成1然后插入,数据库返回的结果为1,就会转换成true然后返回给你。具体如下:

BooleanAndIntConvert.java

package convert;

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; //类型转换器
public class BooleanAndIntConvert extends BaseTypeHandler<Boolean> {
public void setNonNullParameter(PreparedStatement var1, int var2, Boolean var3, JdbcType var4) throws SQLException{
if(var3){ //boolean转成int,true则插入到数据库时插入1,反之插入0
var1.setInt(var2,);
}else{
var1.setInt(var2,);
}
}
//根据列名获取值
public Boolean getNullableResult(ResultSet var1, String var2) throws SQLException{
int sexNum = var1.getInt(var2);
if(sexNum == ) //从数据库当中获取的值为1时,返回true,反之为false
return true;
return false;
}
//根据下标获取值
public Boolean getNullableResult(ResultSet var1, int var2)throws SQLException{
int sexNum = var1.getInt(var2);
if(sexNum == )
return true;
return false;
}
//通过存储过程获取
public Boolean getNullableResult(CallableStatement var1, int var2)throws SQLException{
int sexNum = var1.getInt(var2);
if(sexNum == )
return true;
return false;
}
}

具体逻辑还是比较容易理解的,get,set方法就是当类型不匹配时进行调用,自己书写代码进行匹配

之后再config.xml文件之中进行配置,javaType表示java当中类型,jdbcType表示jdbc之中的,注意下类型名不要写错了,jdbcType枚举类型查一下都有哪些用的时候

<typeHandlers>
<!-- 类型转换器的配置-->
<typeHandler handler="convert.BooleanAndIntConvert" javaType="Boolean" jdbcType="INTEGER"/>
</typeHandlers>

至此,就完成了,然后书写代码查询名字为  哈哈  的person,

List<Person> persons = personMapping.selectPersonByName("哈哈哈");

输出如下,可以看到虽然数据库存的是0,但是我们获取到的却是false,这就类型转换器帮我们自动转换了。

"C:\Program Files\Java\jdk-11.0.1\bin\java.exe" "-javaagent:C:\Program Files\JetBrains\IntelliJ IDEA 2019.1.3\lib\idea_rt.jar=56514:C:\Program Files\JetBrains\IntelliJ IDEA 2019.1.3\bin" -Dfile.encoding=UTF- -classpath C:\learn\java\mybatis\out\production\mybatis;C:\迅雷下载\mybatis-3.5.\mybatis-3.5.\mybatis-3.5..jar;C:\迅雷下载\mysql-connector-java-8.0..jar entity.test
id:
姓名:哈哈哈
爱好:跳舞
性别:false
id:
姓名:哈哈哈
爱好:跳舞
性别:false Process finished with exit code

接口方法传参类型:

首先区分两种传参的方法:

#{name} :如果传入字符串,会自动加上单引号;可防止sql注入

${name}:传入字符串不加单引号,多用于排序查询,或者一些需要拼接的参数,

在书写mapper文件之中的sql语句时,传参可以传入一个变量,一个对象,一个HashMap对象,前两种没什么说的,看下第三种

mapper文件当中,看到paramType="HashMap",之后sql语句里面直接写变量名就行

<!--    map传值-->
<select id="selectPersonByNameAndSex" parameterType="HashMap" resultType="person">
select * from person where `name` = #{name} or `sex` =#{sex}
</select>

接口文件之中方法声明:

List<Person> selectPersonByNameAndSex(Map<String,Object> map);

具体使用时候,初始一个map对象,然后调用映射方法并传入,注意变量名要一致:

Map<String, Object> personMap = new HashMap<>();
personMap.put("name","温鸿飞"); //设置变量的值和名字
personMap.put("sex", "false");
List<Person> persons = personMapping.selectPersonByNameAndSex(personMap)

,一对一,一对多resultMap配置

现在有三张表,person,adress,class,person和adress是一对一关系,person和class是多对一关系

一对一:根据id查询该person以及他的adress信息

    <select id="selectOneById" resultMap="person_adress_map" parameterType="int">
select p.*,a.* from person p
inner join adress a
on p.id = #{id} and p.adressid=a.id
</select>
<resultMap id="person_adress_map" type="person">
<id column="id" property="id"/>
<result property="name" column="name"/>
<result property="loves" column="loves"/>
<result property="sex" column="sex"/>
<result property="adressId" column="adressid"/>
<association property="adress" javaType="Adress"> <!--地址的映射-->
<id column="id" property="id"/>
<result property="place" column="place"/>
<result property="number" column="number"/>
</association>
</resultMap>

property是类中的属性名称,column是数据库当中表的字段名

association标签之中对Person类当中的Adress进行映射

一对多关系:根据传入的班级id查询该班级以及该班级所有学生的信息

    <!-- 一对多关系 -->
<select id="selectPersonByClassId" resultMap="class_person_map" parameterType="int">
select c.*,p.* from person p
inner join class c
on p.classid=c.classid
where c.classid=#{classid}
</select>
<resultMap id="class_person_map" type="class">
<id column="classId" property="classId"/>
<result property="number" column="number"/>
<collection property="persons" ofType="person">
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="loves" column="loves"/>
<result property="sex" column="sex"/>
<result property="classId" column="classId"/>
</collection>
</resultMap>

一对多使用collection标签,注意名称一定要写正确就行了

 

(三)Mybatis类型转换器,接口传参类型,一对一,一对多查询resultMap配置的更多相关文章

  1. mybatis一对多查询resultMap只返回了一条记录

    问题描述:因为领导的一个需求,需要用到使用resultMap,很久没使用了,结果就除了点意外.就记录下这个问题 准备两个类:author(作者)和book(书),数据库创建对应的author-> ...

  2. mybatis入门系列三之类型转换器

    mybatis入门系列三之类型转换器 类型转换器介绍 mybatis作为一个ORM框架,要求java中的对象与数据库中的表记录应该对应 因此java类名-数据库表名,java类属性名-数据库表字段名, ...

  3. Struts 2 类型转换器 输入校验 拦截器

    Struts 2中内建了字符串类型和常见类型之间相互转换的转换器,能满足大多数转换需求,但不能完成字符串和User对象之间的转换. OGNL项目中有一个TypeConvert接口,这个接口是自定义类型 ...

  4. XAML实例教程系列 - 类型转换器(Type Converter)七

    XAML实例教程系列 - 类型转换器(Type Converter) 分类: Windows 8 Silverlight2012-06-25 13:40 961人阅读 评论(0) 收藏 举报 butt ...

  5. wpf中xaml的类型转换器与标记扩展

    原文:wpf中xaml的类型转换器与标记扩展 这篇来讲wpf控件属性的类型转换器 类型转换器 类型转换器在asp.net控件中已经有使用过了,由于wpf的界面是可以由xaml组成的,所以标签的便利也需 ...

  6. struts2视频学习笔记 13-14(自定义局部和全局类型转换器(转换Date格式))

    课时13 自定义类型转换器 局部(对某个action类) package tutorial; import java.util.Date; public class HelloWorld { priv ...

  7. springmvc 类型转换器 数据回显及提示信息

    处理器的写法: 类型转换器的写法: 类型转换器在springmvc.xml中的配置如下: index.jsp的写法:

  8. Mybatis入门——基础方式的增删该查、mapper动态代理方式的CRUD、类型转换器

    一.基础方式的增删该查: 1.mybatis约定:输入参数parameterType和输出参数resulrType在形式上只能有一个. 2.如果输入/输出参数:是简单类型(8个基本类型加String) ...

  9. mybatis类型转换器 - 自定义全局转换enum

    在数据模型.接口参数等场景部分属性参数为一些常量值,比如性别:男.女.若是定义成int或String类型,于是类型本身的范围太宽,要求使用者需要了解底层的业务方可知如何传值,那整体来看增加沟通成本,对 ...

随机推荐

  1. 2018铁人三项测评题 IOS99

    下面这一部分是我从网上复制过来的, 2.IOS 解题链接:http://ctf4.shiyanbar.com/web/IOS/index.php 这题页面中提示系统升级到了IOS99,我们可以想到修改 ...

  2. Spring MVC系列之模型绑定(SpringBoot)(七)

    前言 上一节我们在SpringBoot中启用了Spring MVC最终输出了HelloWorld,本节我们来讲讲Spring MVC中的模型绑定,这个名称来源于.NET或.NET Core,不知是否恰 ...

  3. FTP服务器虚拟用户配置

    FTP服务配置问题及解决方案 使用被动模式,设置云主机IP为被动模式数据传输地址:在配置文件内添加 pasv_enable=YES pasv_promiscuous=YES pasv_address= ...

  4. 天梯 L2 链表去重

    L2-002 链表去重 (25 分) 给定一个带整数键值的链表 L,你需要把其中绝对值重复的键值结点删掉.即对每个键值 K,只有第一个绝对值等于 K 的结点被保留.同时,所有被删除的结点须被保存在另一 ...

  5. 一条SQL注入引出的惊天大案2:无限战争

    前情回顾: 经过黑衣人和老周的合作,终于清除了入侵Linux帝国的网页病毒,并修复了漏洞.不曾想激怒了幕后的黑手,一场新的风雨即将来临. 详情参见:一条SQL注入引出的惊天大案   风云再起 小Q是L ...

  6. 【转】在NetBeans上搭建Android SDK环境

    本文将介绍在NetBeans 6.8上搭建Android SDK环境,目前Android在Netbeans上进行开发需要借助nbandroid的平台插件. 我们刚刚介绍过<MyEclipse上搭 ...

  7. C#实现文件Move操作和文件的Copy操作

    文件移动(Move)操作和文件的复制(Copy)是C#程式开发经常遇到的方法,根据传入的源文件地址和目标文件地址参数,实现对文件的操作.实现代码如下: Move操作代码: public static ...

  8. 重载运算符-operator

    先看段代码: struct node { friend bool operator< (node n1, node n2){ // 优先取最小的,它与下面的 // 是等价的 return n1. ...

  9. RSA 的加密 解密

    RSA加密解密类: package me.hao0.trace.order; import java.io.BufferedReader; import java.io.BufferedWriter; ...

  10. MQ如何解决消息的顺序问题和消息的重复问题?

    一.摘要 分布式消息系统作为实现分布式系统可扩展.可伸缩性的关键组件,需要具有高吞吐量.高可用等特点.而谈到消息系统的设计,就回避不了两个问题: 1.消息的顺序问题 2.消息的重复问题 二.关键特性以 ...