返回顶部
首页 > 资讯 > 精选 >如何解决MyBatis中Enum字段参数解析问题
  • 322
分享到

如何解决MyBatis中Enum字段参数解析问题

2023-06-20 21:06:54 322人浏览 安东尼
摘要

小编给大家分享一下如何解决mybatis中Enum字段参数解析问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!基础Class和TypeHandlerMyBati

小编给大家分享一下如何解决mybatis中Enum字段参数解析问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

基础Class和TypeHandler

MyBatis操作的基本User对象结构如下:

@Data@Alias(value = "user")public class User implements Serializable {    private static final long serialVersionUID = -4947062488310146862L;     private Long id;     @NotNull(message = "用户名不能为空")    private String userName;     @NotNull(message = "备注不能为空")    private String note;     @NotNull(message = "性别不能为空")    private SexEnum sex;}

其中sex字段对应的类型为SexEnum枚举类型,因此同时设置了如下的TypeHandler,从而在前端传入参数和从数据库中取值时进行自动的名称转换。

@MappedJdbcTypes(JdbcType.INTEGER)@MappedTypes(value = SexEnum.class)public class SexTypeHandler extends BaseTypeHandler<SexEnum> {        @Override    public void setNonNullParameter(PreparedStatement preparedStatement, int i, SexEnum sexEnum, JdbcType jdbcType) throws sqlException {        preparedStatement.setInt(i, sexEnum.getId());    }         @Override    public SexEnum getNullableResult(ResultSet resultSet, String s) throws SQLException {        int sex = resultSet.getInt(s);        if (sex != 1 && sex != 2) {            return null;        }        return SexEnum.getEnumById(sex);    }         @Override    public SexEnum getNullableResult(ResultSet resultSet, int i) throws SQLException {        int sex = resultSet.getInt(i);        if (sex != 1 && sex != 2) {            return null;        }        return SexEnum.getEnumById(sex);    }         @Override    public SexEnum getNullableResult(CallableStatement callableStatement, int i) throws SQLException {        int sex = callableStatement.getInt(i);        if (sex != 1 && sex != 2) {            return null;        }        return SexEnum.getEnumById(sex);    }}

请求参数解析问题

下面在使用axiOS post请求来更新用户信息,请求的JSON参数如下:

{      id: id,      userName: username,      sex: sex === 'MALE' ? 1 : 2, // 1: 男,2: 女      note: note}

其中由于sex字段的枚举类型,因此这里将sex根据select得到的option来转换为了枚举中的id对应的值。也就是:

MALE
2: FAMALE

但在发出请求之后,服务端日志中出现如下的问题:

2020-03-02 22:59:50.722  WARN 10864 --- [NIO-8080-exec-2] .w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.Http.converter.HttpMessageNotReadableException: jsON parse error: Cannot deserialize value of type `cn.zyt.SpringBootlearning.domain.SexEnum` from number 2: index value outside legal index range [0..1]; nested exception is com.fasterxml.jackson.databind.exc.InvalidFORMatException: Cannot deserialize value of type `cn.zyt.springbootlearning.domain.SexEnum` from number 2: index value outside legal index range [0..1]
 at [Source: (PushbackInputStream); line: 1, column: 40] (through reference chain: cn.zyt.springbootlearning.domain.User["sex"])]

问题解决

对于该问题,可以使用枚举类型的desc来作为参数传递。当使用如下desc属性映射时,将JSON请求参数改成如下就可以解析成功不报错:

{      id: id,      userName: username,      sex: sex,      note: note}

此时对应的sex字段选择select标签如下:

<tr>  <td>sex:</td>  <td><select name="sex" value={sex} onChange={this.handleChange}>    <option value="MALE">MALE</option>    <option value="FEMALE">FEMALE</option>  </select></td></tr>

同时注意:enum字段sex对应的数据库列的设置中,该列的数据类型为int,而不能为tinyint。tinyint数据类型对应于java中的boolean,1表示true,0表示false。

以上是“如何解决MyBatis中Enum字段参数解析问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: 如何解决MyBatis中Enum字段参数解析问题

本文链接: https://lsjlt.com/news/300203.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何解决MyBatis中Enum字段参数解析问题
    小编给大家分享一下如何解决MyBatis中Enum字段参数解析问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!基础Class和TypeHandlerMyBati...
    99+
    2023-06-20
  • 解决MyBatis中Enum字段参数解析问题
    目录基础Class和TypeHandler请求参数解析问题问题解决基础Class和TypeHandler MyBatis操作的基本User对象结构如下: @Data @Alia...
    99+
    2024-04-02
  • mybatis中@Param注解总是报取不到参数问题如何解决
    这篇文章主要介绍“mybatis中@Param注解总是报取不到参数问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis中@Param注解总是报取不到参数问题如何解决”文章能帮助大...
    99+
    2023-07-02
  • mybatis中字段名与关键字相同问题怎么解决
    这篇文章主要介绍“mybatis中字段名与关键字相同问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis中字段名与关键字相同问题怎么解决”文章能帮助大家解决问题。mybatis中...
    99+
    2023-07-05
  • mybatis中Oracle参数为NULL错误问题及解决
    目录mybatis中Oracle参数为NULL错误问题1.公共配置方法2.参数配置方法mybatis oracle insert 属性为null保存报错 无效的列类型1111解决办法...
    99+
    2022-12-22
    mybatis Oracle Oracle参数为NULL错误 Oracle参数为NULL
  • 如何解决mybatis-plus实体类中出现非数据库映射字段的问题
    本篇内容主要讲解“如何解决mybatis-plus实体类中出现非数据库映射字段”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决mybatis-plus实体类中出现非数据库映射字段”吧!在使...
    99+
    2023-06-07
  • mybatis无参数分页问题怎么解决
    当使用MyBatis进行无参数分页查询时,可以通过在SQL查询语句中使用LIMIT关键字来实现分页。具体步骤如下:1. 在Mappe...
    99+
    2023-08-09
    mybatis
  • np.meshgrid中的indexing参数问题如何解决
    这篇文章主要介绍“np.meshgrid中的indexing参数问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“np.meshgrid中的indexing参数问题如何解决”文章能帮助大家解...
    99+
    2023-07-05
  • 如何解析有关C++参数问题
    本篇文章为大家展示了如何解析有关C++参数问题,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。所谓C++参数的说明,其实是对指定应用而言,它可以是赋予的常数值,在泛指时,它可以是一种变量,用来控制随其...
    99+
    2023-06-17
  • MySql中的longtext字段的返回问题如何解决
    这篇文章主要介绍了MySql中的longtext字段的返回问题如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MySql中的longtext字段的返回问题如何解决文章都会有所收获,下面我们一起来看看吧。M...
    99+
    2023-07-02
  • Mybatis中ResultMap解决属性名和数据库字段名不一致问题
    目录前言1. 字段名不一致解决方法:第一种方式: 起别名第二种方式: 结果集映射 resultMap2. 多对一处理3. 一对多处理小结前言 我们Pojo类的属性名和数据库中的字段名...
    99+
    2024-04-02
  • MYSQL大表改字段慢问题如何解决
    本文小编为大家详细介绍“MYSQL大表改字段慢问题如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“MYSQL大表改字段慢问题如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。MYSQL的ALTER T...
    99+
    2023-07-05
  • 如何解决mybatis-plus实体类中字段和数据库中字段名不对应
    这篇文章主要介绍“如何解决mybatis-plus实体类中字段和数据库中字段名不对应”,在日常操作中,相信很多人在如何解决mybatis-plus实体类中字段和数据库中字段名不对应问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
    99+
    2023-06-07
  • mybatis 实体类字段大小写问题 字段获取不到值的解决
    目录mybatis实体类字段大小写问题 字段获取不到值解决办法推断踩坑mybatis 转换大小写问题解决方法mybatis实体类字段大小写问题 字段获取不到值 由于前期设计问题,项目...
    99+
    2024-04-02
  • mybatis中@Param注解总是报取不到参数问题及解决
    目录@Param注解总是报取不到参数错误如下@Param注解详细使用方法1.@Param这个注解是用来解决接口方法有多个参数时2.可以修饰JavaBean对象、Map集合等3.@Pa...
    99+
    2024-04-02
  • oracle中读写blob字段的问题解析
    LOB类型分为BLOB和CLOB两种:BLOB即二进制大型对像(Binary Large Object),适用于存贮非文本的字节流数据(如程序、图像、影音等)。而CLOB,即字符型大...
    99+
    2022-11-15
    oracle blob
  • Mybatis-Plus系列---【解决null值字段不更新的问题】
    解决null值字段不更新的问题 1.问题 我的MP版本是3.3.2,用Mybatis-Plus的updateById()来更新数据时,无法将字段设置为null值(更新后数据还是原来的值)。 2.分析 默认情况下,Mybatis-Pl...
    99+
    2023-09-18
    mybatis java mysql 开发语言 数据库
  • 解决mybatis update并非所有字段需要更新问题
    目录mybatis update并非所有字段需要更新解决办法mybatis update时遇到的问题mybatis update并非所有字段需要更新 mybatis update 需...
    99+
    2024-04-02
  • 解决使用mybatis取值,字段赋值错误的问题
    目录使用mybatis取值,字段赋值错误mybatis映射赋值失败错误输出错误造成原因解决方法使用mybatis取值,字段赋值错误  我在读取数据库的表信息时,出现了不同字...
    99+
    2024-04-02
  • Mybatis使用concat函数问题如何解决
    这篇文章主要讲解了“Mybatis使用concat函数问题如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mybatis使用concat函数问题如何解决”吧!Mybatis使用conc...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作