- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我想使用 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>
其中整数是id
字符串是 name
.如果您的表中有 200 个类别,您会希望 map 中有 200 个条目,而不是 200 个 map 的列表。
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 的默认 hashmap 并创建单个主 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,然后像这样提取你的主 map :
CategoryResultHandler rh = new CategoryResultHandler();
session.select("getAllCategories", rh);
Map<Integer,String> m = rh.getIdNameMap();
这两个中的一个应该适合你。
最后几点说明:
为什么我要包含 getFromMap()
辅助方法?因为你不能总是控制 MyBatis 返回的 hashmap 中列名的大小写。更多详情:mybatis- 3.1.1. how to override the resultmap returned from mybatis
我在 mybatis-koans 的 Koan26 中有这些解决方案的工作示例(我根据您的问题添加):https://github.com/midpeter444/mybatis-koans
关于java - 在mybatis中返回HashMap,在spring MVC中作为ModelAttribute使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11913013/
我想知道是否可以通过在方法签名中使用另一个 ModelAttribute 注释但不请求映射的方法来链接 @ModelAttribute 方法。这将在 Controller 中。 即 @ModelAtt
这就是现在的样子: @SessionAttributes("shoppingCart") public class ItemController { @ModelAttribute p
在我看来,我生成输入“用户名”,使用属性 multiple=multiple 选择,其名称为“rolesss”。 我的问题是,如果我通过邮寄发送此类表单,我的 Controller 应该将角色转换为列
Controller 中的@ModelAttribute方法是 @ModelAttribute("command") public A getA() { ... } @ModelAttribute p
平台:Spring 3.1.2、Tomcat 7.0.30 从 3.0 升级到 Spring 3.1 后出现此问题 我有一个正常的启用 Spring 的表单:
我对 Spring 3 有疑问。任何人都可以告诉我,在 Controller 中使用这样的方法: @ModelAttribute("nameAtributte") public Customer ge
如本节所述 link下节在方法参数上使用@ModelAttribute An @ModelAttribute on a method argument indicates the argument s
我使用以下形式发送值: ${font.nameFont} Controller : @GetMapping public String main(@Authe
我的问题是:如果请求参数和表单字段具有相同的名称,@ModelAttribute 从请求参数填充表单字段而不是表单 DTO。 示例:我有一个带有名为 name 的输入字段的表单: 给定的表单,其值
我有一个带有 lombok 符号的 User 类 @Getter @Setter @AllArgsConstructor @NoArgsConstructor @Builder class User
请帮帮我。我有这样的 Controller 代码: @RequestMapping(method = RequestMethod.GET) public String showOrders(@Requ
想象一下这样的代码: @RequestMapping(value="/users", method=RequestMethod.GET) public String list(Model model)
我在使用 Spring MVC 3.0 中的 ModelAttribute 时遇到了一个奇怪的问题。当我在本地主机上部署应用程序时,它工作正常。但是当我在远程服务器上部署该应用程序时,每次用户访问特定
我有一个具有许多属性的用户实体(此处未显示一些字段): @Entity public class User { @OneToOne(cascade = ALL, orphanRemoval =
我有一个 Spring 2.5 带注释的 Controller ,其中有一个用 @RequestMapping(method=RequestMethod.GET) 注释的方法,它执行一些逻辑来填充模型
我需要帮助来理解下面的示例 @ModelAttribute来自 Spring文档:(方法 populatePetTypes() ) @Controller @RequestMapping("/owne
我有这样的@Controller: @Controller public class CandidateMenuController{ @ModelAttribute(va
我正在使用 Springfox 和 Swagger 生成 swagger 文件。现在,我正在使用 @ModelAttribute 从对象 (NetworkCmd) 中提取变量,以在 swagger 文
我希望在抽象类中有一个注释为 @ModelAttribute 的通用方法,但具有来自子类的值。最终目标是检索 JSP 中变量的值。每个子类 Controller 中的值都不同,但我不想重复 @Mode
我正在重写一个用内部框架编写的旧 REST 服务以使用 Spring。我有一个带有 POST 方法的 Controller ,该方法将参数作为 POST 或 x-www-form-urlencoded
我是一名优秀的程序员,十分优秀!