多平台统一管理软件接口,如何实现多平台统一管理软件接口
569
2022-09-11
Mybatis之@ResultMap,@Results,@Result注解的使用
目录Mybatis注解@Results、@Result、@ResultMap问题方法一方法二mybatis注释使用resultMap对应的注释,及对应注解Results、Result、One、Many的使用1.@Results注解2.@Resutl注解3.@One注解(一对一)4.@Many注解(多对一)
Mybatis注解@Results、@Result、@ResultMap
问题
在使用mybatis时发现,mybatis能自动匹配实体名和数据库字段名相同的字段。当有实体名与数据库的字段名不同时该如何解决??
数据库的表对应的列名:
springboot项目中建的实体类为:
public class MapModel {
private Long key;
private String value;
//省略getter、setter方法
}
方法一
给查询字段另起名对应实体类的名称:
@Select("SELECT province_id as key , province_name as value FROM `j_position`")
public List
方法二
使用@Results、@Result、@ResultMap注解:
@Select("SELECT province_id, province_name FROM `j_position`")
@Results(id="resultMap1" ,value = {
@Result(property = "key",column = "province_id"),
@Result(property = "value",column ="province_name")
})
public List
其中定义的id="resultMap1"可以使用
@ResultMap("resultMap1)
@Select("SELECT province_id, province_name FROM `j_position` where province_name=#{name}")
public List
推荐使用方法二!
mybatis注释使用
resultMap对应的注释,及对应注解Results、Result、One、Many的使用
有一部分建立在我上一个博客,mybatis注释使用(单表查询),如果那里看不懂了,建议看下我上一个博客(里面所有的配置文件,接口,数据库的创建都有说明)
1.@Results注解
代替的是标签
该注解中可以使用单个@ResxbKNPFWxGult注解,也可以使用@Result集合
@Results({@Result(),@Result()})或@Results(@Result())
注意:使用注解是若报出org.apache.ibatis.binding.BindingException:Invalid bound statement (not found):接口全类名.方法名
可能是使用@Results注解时忘记使用@Select注解
2.@Resutl注解
代替了
@Result 中 属性介绍:
column 数据库的列名
Property需要装配的属性名
one 需要使用的@One注解(@Result(one=@One)()))
many 需要使用的@Many注解(@Result(many=@many)()))
3.@One注解(一对一)
代替了
@One注解属性介绍:
select 指定用来多表查询的sqlmapper
fetchType会覆盖全局的配置参数lazyLoadingEnabled。。
使用格式:
@Result(column=" ",property="",one=@One(select=""))
4.@Many注解(多对一)
代替了
注意:聚集元素用来处理“一对多”的关系。需要指定映射的java实体类的属性,属性的javaType(一般为ArrayList)但是注解中可以不定义;
使用格式:
@Result(property="",column="",many=@Many(select=""))
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~