sqlSession的selectOne方法返回值不用强转详解

今天在写代码的时候,发现一个问题就是

当使用快捷键自动生成的时候slqSession.selectOne方法的返回值是Object类型

Object o = sqlSession.selectOne("test.selectEmployeeById", 7);

而我写代码的时候直接写Employee,没有强转也没报错.

Employee employee = sqlSession.selectOne("test.selectEmployeeById", 7);

按理说从大范围向小范围转换应该是需要强转的,这里不转也没报错有点疑惑

查看了一下源码:

<T> T selectOne(java.lang.String s, java.lang.Object o);

原来这个方法的返回值是泛型,泛型是个什么呢,就是很灵活.一开始不知道返回什么类型的时候,就可以返回泛型.

根据网上查询,详细的了解了一下

泛型详解:

譬如说在定义selectOne这个方法的时候.肯定要考虑如何给调用者正确的返回值类型,并且不需要调用者自己去qiangzhuan类型,如果这个方法的返回值类型是Object类型,那么调用者拿到这个Object类型就需要强转为表对应的java bean类型.

但是如果使用泛型,那就不一样了.泛型在运行时才确定真正的类型,而非编译时.这个就很牛逼了,所以最后根本不需要强转了.

今天是被泛型征服的一天,耶!

 

例子:


1. 服务提供者 函数: 

//通过<T>声明告诉JVM返回值定义一个泛型 T        

这里的T只是个占位符的效果,26个字母随便写哪个字母都可以,但一定要是和< >里面相同的字母,这里使用T

public <T> T findList(String sqlID,Map<String,Object> params) {

String statement = "com.mybatis.mapping.userMapper."+sqlID;//映射sql的标识字符串

return (T) this.session.selectList(statement, params);
}

2. 服务调用者 函数:

//这里接收的类型声明直接写真实的类型就可以,无需强制转换

List<SubsHis> list = jdbc.findList("getSubsHisList", map);

 

参考博文:
https://blog.csdn.net/junzhen_chen/article/details/74357234

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值