MyBatis中使用@Results注解来映射查询结果集到实体类属性。
(1)@Results的基本用法。当数据库字段名与实体类对应的属性名不一致时,可以使用@Results映射来将其对应起来。column为数据库字段名,porperty为实体类属性名,jdbcType为数据库字段数据类型,id为是否为主键。
(2)连表查询时使用Results注解可以查询连接的表的数据
@Select("select menu.id, menu.parent_id,menu.name,menu.url,menu.icon,menu.sort,menu.description,\n" +
"menu_vs_role.role_id,role.name,user_vs_role.user_id \n" +
"from menu \n" +
"left join menu_vs_role on menu.id=menu_vs_role.menu_id \n" +
"left join role on menu_vs_role.role_id=role.id \n" +
"left join user_vs_role on role.id=user_vs_role.role_id where user_vs_role.user_id=#{user_id}")
@Results({
@Result(column = "id",property = "id", jdbcType= JdbcType.INTEGER, id=true),
@Result(column = "parent_id",property = "parent_id"),
@Result(column = "name",property = "name"),
@Result(column = "url",property = "url"),
@Result(column = "sort",property = "sort"),
@Result(column = "description",property = "description"),
@Result(column = "role_id",property = "menu_vs_role.role_id"), // 可以实现连表查询menu_vs_role的数据
@Result(column = "name",property = "role.name"),
@Result(column = "user_id",property = "user_vs_role.user_id")
})
List<Menu> findMenuListByUserId(int user_id);
本文详细介绍了MyBatis框架中@Results注解的使用方法,包括基本用法和连表查询的应用。通过实例展示了如何解决数据库字段名与实体类属性名不一致的问题,以及如何在连表查询中正确映射多个表的数据。
559

被折叠的 条评论
为什么被折叠?



