洞察探索open banking如何通过小程序容器技术助力金融企业实现数据安全和数字化转型
1102
2022-12-23
MyBatis在DAO层定义接口返回类型泛型无效的解决
MyBatis DAO层定义接口返回类型泛型无效
今天很偶然的因为一次粗心而发现的一个mybatis问题,这里就写出来与大家分享一下。
DAO层定义了一个接口,返回String集合,用于获取最热门的搜索信息。
mapper.xml文件接口返回的类型却是search对象。
调用接口,返回的是search对象集合,没有报错,EOlYVo泛型没起到作用。
仔细一想,泛型是在编译阶段将我们的返回值类型匹配到一具体类型,而DAO层的接口却没有具体的返回值信息,所以在编译阶段它是可以通过的,这也就是说我们在DAO层定义的接口返回值泛型是不起作用的,具体的类型还是得依靠mapper.xml文件中定义的返回值类型为准。
那如果我们定义了泛型,并根据泛型来操作数据是不是会报错呢?
我特地实验了一番。mapper.xml查询实际返回的是Person对象,而我使用的Animal对象集合去接收,并对集合进行了遍历操作
最后报了ClassCastException,所以得出结论,DAO层接口定义的返回值泛型是没有用的,实际返回需要根据具体的mapper.xml文件对应的方法返回值来确定。
但是我们却可
EOlYVo
以根据泛型类型来进行数据的操作,这也不算是bug,只是泛型和mybatis没有很好的融合吧,个人理解。
注意:
mybatis的DAO层接口与mapper.xml文件的对应是通过代理类来实现的,有两种方式,一种是通过namespace来对应,一种是放在同一路径下,但是要确保接口文件和xml文件名字相同。
MyBatis返回类型
分类及返回值类型
对应的分类为
1、resultMap
2、resultType
对应返回值类型
1、resultMap:结果集
2、resultType:int,string ,long ,class
要点
在MyBatis进行查询映射时,其实查询出来的每一个属性都是放在一个对应的Map里面的,其中键是属性名,值则是其对应的值。
1、当提供的返回类型属性是resultType时,MyBatis会将Map里面的键值对取出赋给resultType所指定的对象对应的属性。所以其实MyBatis的每一个查询映射的返回类型都是ResultMap,只是当提供的返回类型属性是resultType的时候,MyBatis对自动的给把对应的值赋给resultType所指定对象的属性。
2、当提供的返回类型是resultMap时,因为Map不能很好表示领域模型,就需要自己再进一步的把它转化为对应的对象,这常常在复杂查询中很有作用。
resultMap案例
select
from common_car_make
where id = #{EOlYVoid,jdbcType=BIGINT}
</select>
resultType--long案例
select count(*) from common_car_type cm
where 1=1
and cm.car_model_id = #{carModelId,jdbcType=DECIMAL}
resultType--int案例
select count(1)
from common_category_brand
where 1=1
and category_id = #{categoryId,jdbcType=BIGINT}
and brand_id = #{brandId,jdbcType=BIGINT}
resultType--class案例:查询结果对应类中的属性值
select id, brand_name brandName, brand_type brandType, icon, delete_flag deleteFlag
from common_brand
where id = #{id,jdbcType=BIGINT}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~