我想使用spring mvc @modelAttribute在我的Jsp页面中显示类别列表。
在我的mapper.xml文件中是
<select id="selectAllCategories" resultMap="BaseResultMap">
select id, name from categories
</select>
在我的Mapper.java类中,我有方法
List<Map<String, String>> selectAllCategories();
我想要一个这样的方法:
Map<Integer, String>`selectAllCategories();
而不是List<Map<>>
,这可能吗?
您想获得一个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();
这两个之一应该为您工作。
我正在使用Spring形式。我只需要得到Staemap作为响应,但我得到的是整个jsp页面作为响应。
问题内容: 我在SpringMVC项目中将新的Java API(JSR 353)用于JSON。 这个想法是生成一些Json数据并将其返回给客户端。我所拥有的控制器看起来像这样: 当我访问它时,我没有得到JSON的预期表示,而是得到了这些: 为什么是这样?到底是怎么回事?以及如何使其正确返回预期的JSON? 问题答案: 当您意识到新的JSR 353 API 没有特殊要求时,答案很简单。相反,在这种情
我有class-user,它看起来如下所示: 这两个哈希映射包含未知的键和字符串类型的值(它们给我带来了很多麻烦)。 我已经使用insert方法将该类映射到表中。并将其映射到下表方案: 我有什么方法来处理这些hasmaps? 谢谢!
本文向大家介绍Mybatis中返回Map的实现,包括了Mybatis中返回Map的实现的使用技巧和注意事项,需要的朋友参考一下 在Mybatis中,我们通常会像下边这样用: 返回一个结果 返回多个结果(其实这个和上边一样,只不过是查询条件的控制而已) 我们只要将上边的resultType改为java.util.HashMap,这会有生成下边这样 上这结果就是说,以User类的属性名为key,属性值
因此,我创建了我的对象数组,每个对象都被初始化为一个新字节[1024]: 然后,我遍历这个数组中的所有索引,执行如下操作: 在大多数情况下,一切都很好。但是,如果我希望每个字节数组都是可变长度的呢?也就是说,我希望字节数组的数组是“锯齿状”的。我将什么作为最后一个参数传递给NewObjectArray()作为初始值?我尝试传递0作为初始值,以防止在创建jobjectArray时进行初始化,然后分配
问题内容: 我正在尝试用Python做某事,但我陷入了困境。我在Couchdb中有一个用户列表(使用python benchdb库和Flask框架),这些用户具有用户名(即_id)和电子邮件。我想在jinja2模板的选择框中使用电子邮件地址列表。 我的第一个问题是如何访问电子邮件地址。如果我做: 我得到: 这样我就可以获得我的电子邮件列表。但是我残酷的经验不足之处在于我不知道该如何使用它们。该列表