广告
返回顶部
首页 > 资讯 > 精选 >如何解决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://www.lsjlt.com/news/300203.html(转载时请注明来源链接)

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 解决MyBatis中Enum字段参数解析问题
    目录基础Class和TypeHandler请求参数解析问题问题解决基础Class和TypeHandler MyBatis操作的基本User对象结构如下: @Data @Alia...
    99+
    2022-11-12
  • 如何解决MyBatis中Enum字段参数解析问题
    小编给大家分享一下如何解决MyBatis中Enum字段参数解析问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!基础Class和TypeHandlerMyBati...
    99+
    2023-06-20
  • mybatis中字段名与关键字相同问题怎么解决
    这篇文章主要介绍“mybatis中字段名与关键字相同问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis中字段名与关键字相同问题怎么解决”文章能帮助大家解决问题。mybatis中...
    99+
    2023-07-05
  • mybatis中@Param注解总是报取不到参数问题如何解决
    这篇文章主要介绍“mybatis中@Param注解总是报取不到参数问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis中@Param注解总是报取不到参数问题如何解决”文章能帮助大...
    99+
    2023-07-02
  • mybatis中Oracle参数为NULL错误问题及解决
    目录mybatis中Oracle参数为NULL错误问题1.公共配置方法2.参数配置方法mybatis oracle insert 属性为null保存报错 无效的列类型1111解决办法...
    99+
    2022-12-22
    mybatis Oracle Oracle参数为NULL错误 Oracle参数为NULL
  • Mybatis中ResultMap解决属性名和数据库字段名不一致问题
    目录前言1. 字段名不一致解决方法:第一种方式: 起别名第二种方式: 结果集映射 resultMap2. 多对一处理3. 一对多处理小结前言 我们Pojo类的属性名和数据库中的字段名...
    99+
    2022-11-12
  • 如何解决mybatis-plus实体类中出现非数据库映射字段的问题
    本篇内容主要讲解“如何解决mybatis-plus实体类中出现非数据库映射字段”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决mybatis-plus实体类中出现非数据库映射字段”吧!在使...
    99+
    2023-06-07
  • mybatis中@Param注解总是报取不到参数问题及解决
    目录@Param注解总是报取不到参数错误如下@Param注解详细使用方法1.@Param这个注解是用来解决接口方法有多个参数时2.可以修饰JavaBean对象、Map集合等3.@Pa...
    99+
    2022-11-13
  • MYSQL大表改字段慢问题如何解决
    本文小编为大家详细介绍“MYSQL大表改字段慢问题如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“MYSQL大表改字段慢问题如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。MYSQL的ALTER T...
    99+
    2023-07-05
  • np.meshgrid中的indexing参数问题如何解决
    这篇文章主要介绍“np.meshgrid中的indexing参数问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“np.meshgrid中的indexing参数问题如何解决”文章能帮助大家解...
    99+
    2023-07-05
  • MySql中的longtext字段的返回问题如何解决
    这篇文章主要介绍了MySql中的longtext字段的返回问题如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MySql中的longtext字段的返回问题如何解决文章都会有所收获,下面我们一起来看看吧。M...
    99+
    2023-07-02
  • 如何解析有关C++参数问题
    本篇文章为大家展示了如何解析有关C++参数问题,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。所谓C++参数的说明,其实是对指定应用而言,它可以是赋予的常数值,在泛指时,它可以是一种变量,用来控制随其...
    99+
    2023-06-17
  • 使用MyBatis时数据库字段和实体字段不同如何解决
    这期内容当中小编将会给大家带来有关使用MyBatis时数据库字段和实体字段不同如何解决,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。当数据库字段和实体bean中属性不一致时之前数据库Person名字字段是...
    99+
    2023-05-31
    mybatis 实体字段 数据库字段
  • 如何解决mybatis-plus实体类中字段和数据库中字段名不对应
    这篇文章主要介绍“如何解决mybatis-plus实体类中字段和数据库中字段名不对应”,在日常操作中,相信很多人在如何解决mybatis-plus实体类中字段和数据库中字段名不对应问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
    99+
    2023-06-07
  • mybatis plus 查询数据库字段名自动添加下划线问题解决
    实体类和数据库中的字段名是一致的,但报错Unknown column 'dept_id' in 'field list',这是因为plus中的驼峰命名法,会自动添加下划线。 关闭驼峰式命名转换为下划线 在配置文件中加一个: mybatis...
    99+
    2023-09-01
    mybatis java mysql
  • Mybatis使用concat函数问题如何解决
    这篇文章主要讲解了“Mybatis使用concat函数问题如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mybatis使用concat函数问题如何解决”吧!Mybatis使用conc...
    99+
    2023-07-05
  • Mybatis中怎么使用ResultMap解决属性名和数据库字段名不一致问题
    本篇内容介绍了“Mybatis中怎么使用ResultMap解决属性名和数据库字段名不一致问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前...
    99+
    2023-06-25
  • C#输出参数out问题如何解决
    这篇文章主要讲解了“C#输出参数out问题如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#输出参数out问题如何解决”吧!C# 输出参数out什么是输出参数方法声明时,使用out修...
    99+
    2023-07-05
  • thinkphp参数不正确问题如何解决
    这篇文章主要介绍“thinkphp参数不正确问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“thinkphp参数不正确问题如何解决”文章能帮助大家解决问题。一、什么是“参数不正确”通常,当...
    99+
    2023-07-05
  • php url中文参数乱码问题如何解决
    这篇文章主要讲解了“php url中文参数乱码问题如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php url中文参数乱码问题如何解决”吧!乱码问题的原因在 PHP 中处理中文参数时...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作