温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题

发布时间:2021-07-30 18:16:21 来源:亿速云 阅读:306 作者:chen 栏目:开发技术

这篇文章主要讲解了“如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题”吧!

MyBatis DAO层定义接口返回类型泛型无效

今天很偶然的因为一次粗心而发现的一个mybatis问题,这里就写出来与大家分享一下。

如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题

DAO层定义了一个接口,返回String集合,用于获取最热门的搜索信息。

如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题

mapper.xml文件接口返回的类型却是search对象。

如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题

调用接口,返回的是search对象集合,没有报错,泛型没起到作用。

仔细一想,泛型是在编译阶段将我们的返回值类型匹配到一具体类型,而DAO层的接口却没有具体的返回值信息,所以在编译阶段它是可以通过的,这也就是说我们在DAO层定义的接口返回值泛型是不起作用的,具体的类型还是得依靠mapper.xml文件中定义的返回值类型为准。

那如果我们定义了泛型,并根据泛型来操作数据是不是会报错呢?

我特地实验了一番。mapper.xml查询实际返回的是Person对象,而我使用的Animal对象集合去接收,并对集合进行了遍历操作

如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题

如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题

如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题

如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题

最后报了ClassCastException,所以得出结论,DAO层接口定义的返回值泛型是没有用的,实际返回需要根据具体的mapper.xml文件对应的方法返回值来确定。

但是我们却可以根据泛型类型来进行数据的操作,这也不算是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 id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Long" > 
    select   
    <include refid="Base_Column_List" />  
    from common_car_make  
    where id = #{id,jdbcType=BIGINT}  
</select>

resultType--long案例

<select id="queryCarTypeByModelIdCount" resultType="java.lang.Long" parameterType="java.util.Map">  
     select count(*)  from common_car_type cm  
     where 1=1  
     <if test="carModelId != null">  
         and  cm.car_model_id = #{carModelId,jdbcType=DECIMAL}  
     </if>  
</select>

resultType--int案例

<select id="queryCategoryBrandCount" resultType="java.lang.Integer" parameterType="java.util.HashMap" >  
      select count(1)  
      from common_category_brand  
      where 1=1  
      <if test="categoryId != null" >  
          and category_id = #{categoryId,jdbcType=BIGINT}  
      </if>  
      <if test="brandId != null" >  
          and brand_id = #{brandId,jdbcType=BIGINT}  
      </if>  
</select>

resultType--class案例:查询结果对应类中的属性值

<select id="selectCommonBrand" resultType="com.epeit.api.model.CommonBrandPo" parameterType="java.lang.Long" >  
    select id, brand_name brandName, brand_type brandType, icon, delete_flag deleteFlag  
    from common_brand  
    where id = #{id,jdbcType=BIGINT}  
</select>

感谢各位的阅读,以上就是“如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题”的内容了,经过本文的学习后,相信大家对如何解决MyBatis在DAO层定义接口返回类型泛型无效的问题这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI