平时咱们写程序实体类内或多或少都会有枚举类型属性,方便嘛。但是mybatis里怎么处理他们的增删改查呢?

要求:

插入的时候,会用枚举的定义插入数据库,我们希望在数据库中看到的是数字或者其他东西;

查询的时候,数据库的值可以自动转换为我们对应的枚举值。

举例,我有一个这样的枚举类型:

Java Code复制内容到剪贴板
  1. ),
  2. );
  3. private int status;
  4. UserStatus(int status){
  5. this.status = status;
  6. }
  7. public int getStatus() {
  8. return status;
  9. }
  10. }

我们插入数据库中,数据库应该为我们保存0或者1

我们可以使用mybatis自带的枚举类型EnumOrdinalTypeHandler

举例如下:

Java Code复制内容到剪贴板
  1. <insert id="addUser" parameterType="User">
  2. INSERT INTO t_user(USER_ID,USER_NAME,LOGIN_NAME,
  3. LOGIN_PASSWORD,USER_STATUS,CREATE_TIME,UPDATE_TIME)
  4. VALUES(
  5. #{user_id},
  6. #{user_name},
  7. #{login_name},
  8. #{login_password},
  9. #{user_status, typeHandler=org.apache.ibatis.type.EnumOrdinalTypeHandler},
  10. #{create_time},
  11. #{update_time}
  12. )
  13. </insert>

我们的UserStatus插入的时候是UserStatus.AVAILABLE

执行完毕后,看结果:

看,是不是结果是我们期望的那样。

但是问题来了?

我们查询的时候报错了:Error querying database.  Cause: java.lang.IllegalArgumentException: No enum constant cn.com.shuyangyang.mybatis.UserStatus.1

我们可以自定义这样的一个EnumStatusHandler:

Java Code复制内容到剪贴板
  1. package cn.com.shuyangyang.mybatis;
  2. import java.sql.CallableStatement;
  3. import java.sql.PreparedStatement;
  4. import java.sql.ResultSet;
  5. import java.sql.SQLException;
  6. import org.apache.ibatis.type.BaseTypeHandler;
  7. import org.apache.ibatis.type.JdbcType;
  8. /**
  9. * Mybatis自定义转换类型
  10. * @author ShuYangYang
  11. * E-Mail:shuyangyang@aliyun.com
  12. * http://www.shuyangyang.com.cn
  13. * Date:2015年1月26日下午10:12:54
  14. *
  15. */
  16. public class EnumStatusHandler extends BaseTypeHandler<UserStatus> {
  17. private Class<UserStatus> type;
  18. private final UserStatus[] enums;
  19. /**
  20. * 设置配置文件设置的转换类以及枚举类内容,供其他方法更便捷高效的实现
  21. * @param type 配置文件中设置的转换类
  22. */
  23. public EnumStatusHandler(Class<UserStatus> type) {
  24. if (type == null)
  25. throw new IllegalArgumentException("Type argument cannot be null");
  26. this.type = type;
  27. this.enums = type.getEnumConstants();
  28. if (this.enums == null)
  29. throw new IllegalArgumentException(type.getSimpleName()
  30. + " does not represent an enum type.");
  31. }
  32. @Override
  33. public void setNonNullParameter(PreparedStatement ps, int i,
  34. UserStatus parameter, JdbcType jdbcType) throws SQLException {
  35. // baseTypeHandler已经帮我们做了parameter的null判断
  36. ps.setInt(i, parameter.getStatus());
  37. }
  38. @Override
  39. public UserStatus getNullableResult(ResultSet rs, String columnName)
  40. throws SQLException {
  41. // 根据数据库存储类型决定获取类型,本例子中数据库中存放INT类型
  42. int i = rs.getInt(columnName);
  43. if (rs.wasNull()) {
  44. return null;
  45. } else {
  46. // 根据数据库中的code值,定位EnumStatus子类
  47. return locateEnumStatus(i);
  48. }
  49. }
  50. @Override
  51. public UserStatus getNullableResult(ResultSet rs, int columnIndex)
  52. throws SQLException {
  53. // 根据数据库存储类型决定获取类型,本例子中数据库中存放INT类型
  54. int i = rs.getInt(columnIndex);
  55. if (rs.wasNull()) {
  56. return null;
  57. } else {
  58. // 根据数据库中的code值,定位EnumStatus子类
  59. return locateEnumStatus(i);
  60. }
  61. }
  62. @Override
  63. public UserStatus getNullableResult(CallableStatement cs, int columnIndex)
  64. throws SQLException {
  65. // 根据数据库存储类型决定获取类型,本例子中数据库中存放INT类型
  66. int i = cs.getInt(columnIndex);
  67. if (cs.wasNull()) {
  68. return null;
  69. } else {
  70. // 根据数据库中的code值,定位EnumStatus子类
  71. return locateEnumStatus(i);
  72. }
  73. }
  74. /**
  75. * 枚举类型转换,由于构造函数获取了枚举的子类enums,让遍历更加高效快捷
  76. * @param code 数据库中存储的自定义code属性
  77. * @return code对应的枚举类
  78. */
  79. private UserStatus locateEnumStatus(int code) {
  80. for(UserStatus status : enums) {
  81. if(status.getStatus()==(Integer.valueOf(code))) {
  82. return status;
  83. }
  84. }
  85. throw new IllegalArgumentException("未知的枚举类型:" + code + ",请核对" + type.getSimpleName());
  86. }
  87. }

mapper.xml里这样配置:

XML/HTML Code复制内容到剪贴板
  1. <resultMap type="User" id="userResult">
  2. ……省略其他属性配置
  3. <result column="USER_STATUS" property="user_status" typeHandler="cn.com.shuyangyang.mybatis.EnumStatusHandler"/>
  4. ……省略其他属性配置
  5. </resultMap>

现在来看看结果:

[User [user_id=782cba19-559f-41c3-a1b0-25fcac4cf118, user_name=系统管理员, login_name=admin, login_password=admin,user_status=AVAILABLE, create_time=Mon Jan 26 21:17:09 CST 2015, update_time=Mon Jan 26 21:17:09 CST 2015]]

完美结果。

MyBatis对于Java对象里的枚举类型处理的更多相关文章

  1. Java基础教程:枚举类型

    Java基础教程:枚举类型 枚举类型 枚举是将一具有类似特性的值归纳在一起的方法.比如,我们可以将周一到周日设计为一个枚举类型.彩虹的七种颜色设计为一个枚举类型. 常量实现枚举 我们通过定义常量的方式 ...

  2. 创建Java不可变型的枚举类型Gender

    创建Java不可变型的枚举类型,其实例如下: // 创建不可变型的枚举类 enum Gender { // 此处的枚举值必须调用对应的构造器来创建 MALE("男"), FEMAL ...

  3. Java魔法堂:枚举类型详解

    一.前言 Java的枚举类型相对C#来说具有更灵活可配置性,Java的枚举类型可以携带更多的信息. // C# enum MyColor{ RED = , BLUE = } Console.Write ...

  4. mybatis 查询单个对象,结果集类型一定要明确

    简单介绍:用ssm框架已经有很长时间了,但是似乎从来都没有对于查询单个对象,存在问题的,好像也就是那回事,写完sql就查出来了,也从来都没有认真的想过,为什么会这样,为什么要设置结果集类型 代码: / ...

  5. Java基础教程(15)--枚举类型

      枚举类型定义了一个枚举值的列表,每个值是一个标识符.例如,下面的语句声明了一个枚举类型,用来表示星期的可能情况: public enum Day { SUNDAY, MONDAY, TUESDAY ...

  6. java对象转化成String类型

    在java项目的实际开发和应用中,常常需要用到将对象转为String这一基本功能.本文将对常用的转换方法进行一个总结.常用的方法有Object#toString(),(String)要转换的对象,St ...

  7. Java中的Enum枚举类型总结

    废话不多说,直接上代码,该例子来源于:http://docs.oracle.com/javase/tutorial/java/javaOO/enum.html public enum Planet { ...

  8. java对象中含有Integer类型字段转json字符串问题

    问题:对于含有Integer类型字段的java对象,在通过下面这种方式转为json字符串时,Integer类型的字段如果为空的情况下,会默认转化为0,但是我想让它为空的时候直接转化为null,不要默认 ...

  9. Java练习 SDUT-1959_简单枚举类型——植物与颜色

    简单枚举类型--植物与颜色 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 请定义具有red, orange, yell ...

随机推荐

  1. 自定义一个可以被序列化的泛型Dictionary<TKey,TValue>集合

    Dictionary是一个键值类型的集合.它有点像数组,但Dictionary的键可以是任何类型,内部使用Hash Table存储键和值.本篇自定义一个类型安全的泛型Dictionary<TKe ...

  2. DELPHI NEXTGEN编译开关

    DELPHI NEXTGEN编译开关 {$IFDEF NEXTGEN} UTF8String = type _AnsiString(65001); RawByteString = type _Ansi ...

  3. 在后台运行rtorrent

    本来一直是用transmission做PT的客户端的,但是transmission的功能实在是太弱了,web-gui显示的信息也实在是太有限.在别人的推荐下,总算下定决心换rtorrent+wtorr ...

  4. 【elasticsearch】关于elasticSearch的基础概念了解【转载】

    转载原文:https://www.cnblogs.com/chenmc/p/9516100.html 该作者本系列文章,写的很详尽 ================================== ...

  5. 绝望的主妇第一二三季/Desperate Housewives迅雷下载

    绝望主妇 第一二三季 Desperate Housewives Season 1 2 3(2004 2005 2006) 本季看点:在紫藤街上住着这样一群主妇:拥有四个孩子和一个如孩子一般的丈夫的女强 ...

  6. XML和JSON优缺点

    <1>.XML的优点 A.格式统一,符合标准: B.容易与其他系统进行远程交互,数据共享比较方便.<2>.XML的缺点 A.XML文件庞大,文件格式复杂,传输占带宽: B.服务 ...

  7. 试用ArcGIS Server 10.1 X64 for windows

    ArcGIS 10.1 发布已经很久了,其Server只支持x64,为此我还专门下载安装了windows Server 2003 x64,进行安装测试. 我测试了集群功能,比起10.0 ,没有使用域控 ...

  8. PL2303 Windows8.1驱动

    常用的USB转串口下载芯片驱动可以参照我这篇文章USB转串口 FT232/PL2303/CH340 驱动以及使用体会 ,今天有找出了那根串口线打算使用,由于系统已经换为Windows8.1 X64所以 ...

  9. Oracle简单的备份和恢复-导入和导出-目录

    ylbtech-Oracle:Oracle简单的备份和恢复-导入和导出-目录 Oracle安全运行离不开良好的备份和恢复机制,因为我们不是DBA.所以我们也就不过多的讲解DBA的备份和恢复.作为程序员 ...

  10. 在ASP.NET MVC中以post方式传递数组参数的示例【转】

    最近在工作中用到了在ASP.NET MVC中以post方式传递数组参数的情况,记录下来,以供参考. 一.准备参数对象 在本例中,我会传递两个数组参数:一个字符串数组,一个自定义对象数组.这个自定义对象 ...