栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在mybatis中返回HashMap并将其用作Spring MVC中的ModelAttribute

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在mybatis中返回HashMap并将其用作Spring MVC中的ModelAttribute

您想获得一个

Map<Integer,String>
Integer是
id
和String是the的地方
name
。如果表中有200个类别,则您需要200个条目,而不是200个列表。

MyBatis不能完全做到这一点,但是您可以使用其功能来做到这一点。我看到两个选择。

选项1:

第一个不是您所要求的,但是值得展示。它为您提供了一个

Map<Integer,Category>
类别,其中类别是具有ID,名称(以及类别表中的其他字段)的类别表的域对象。创建Category域对象之后,在MyBatis中使用
@MapKey
批注很容易做到这一点:

@Select("SELECT id, name FROM categories")@MapKey("id")Map<Integer,Category> getAllCategories();

然后在您的代码中执行以下操作:

MyMapper mapper = session.getMapper(MyMapper.class);Map<Integer,Category> m = mapper.getAllCategories();

根据您是否可以将名称提取为Category对象的属性,这可能对您的用例不起作用。

选项2:

为了得到

Map<Integer,String>
您的要求,我知道的最简单的方法是创建一个实现MyBatis
ResultHandler接口的类。

您的ResultHandler将使用MyBatis创建的column-name => column-value的默认哈希图,并创建单个主Map。这是代码:

public class CategoryResultHandler implements ResultHandler {  Map<Integer,String> inMap = new HashMap<Integer,String>();  public Map<Integer, String> getIdNameMap() {    return inMap;  }  @Override  public void handleResult(ResultContext rc) {    @SuppressWarnings("unchecked")    Map<String,Object> m = (Map<String,Object>)rc.getResultObject();    inMap.put((Integer)getFromMap(m, "id"),    (String)getFromMap(m, "name"));  }  // see note at bottom of answer as to why I include this method  private Object getFromMap(Map<String, Object> map, String key) {    if (map.containsKey(key.toLowerCase())) {      return map.get(key.toLowerCase());    } else {      return map.get(key.toUpperCase());    }  }}

类别表中的每一行都会调用一次handleResult方法。您告诉MyBatis使用ResultHandler,然后像这样提取您的主地图:

CategoryResultHandler rh = new CategoryResultHandler();session.select("getAllCategories", rh);Map<Integer,String> m = rh.getIdNameMap();

这两个之一应该为您工作。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/369084.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号