浅谈为什么要使用mybatis的@param
起因
我们先来看一个报错
报错很简单,参数 start 没找到。
我是在实现一个 API 接口时发现了一个问题,当我不使用 @Param 标签时,mybatis 是不认识哪个参数叫什么名字的,尽管我定义了 (long start,long end) 它仍然不认识。在这个接口上,我希望根据前端传来的参数,查找指定范围的数据,例如:我想搜索第二页的数据,假设一页20个,那么搜索的范围就是21-40,于是就会调用接口中的 getTypeListByRange 来查找对应 mapper 的 SQL 语句。
public interface TypeDao { Type getTypeByid(long id); List<Type> getTypeListAll(); List<Type> getTypeListByRange(long start,long end); }
解释 @Param
org.apache.ibatis.annotations.Param 当映射器方法需要多个参数时,这个注解可以被用于:给映射器方法中的每个参数来取一个名字。否则,多参数将会以它们的顺序位置和SQL语句中的表达式进行映射,这是默认的。
语法要求:若使用@Param(“id”),则SQL中参数应该被命名为:#{id}。
使用
Dao 层
import org.apache.ibatis.annotations.Param; import com.caeser.upmovie.entity.Type; public interface TypeDao { Type getTypeByid(long id); List<Type> getTypeListAll(); List<Type> getTypeListByRange(@Param("start")long start,@Param("end")long end); }
Mapper
<select id="getTypeListByRange" resultType="com.caeser.upmovie.entity.Type"> SELECT ID, NAME, CREATE_TIME, UPDATE_TIME FROM upm_type LIMIT #{start},#{end}; </select>
单元测试
public class TypeTest extends BaseTest{ @Autowired private TypeDao typeDao; @Test public void testDao(){ List<Type> typeList1=typeDao.getTypeListByRange(1, 4); for(int i=0;i<typeList1.size();i++){ System.out.println(typeList1.get(i).getName()); } } }
结果
总结
当 Dao 层传递参数为多个参数时,为了规范,必须使用 @Param 给参数命名。这里需要注意,使用的是 mybatis 的 param 来命名。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
SpringBoot+SpringCache实现两级缓存(Redis+Caffeine)
这篇文章主要介绍了SpringBoot+SpringCache实现两级缓存(Redis+Caffeine),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2021-04-04深入学习java并发包ConcurrentHashMap源码
这篇文章主要介绍了深入学习java并发包ConcurrentHashMap源码,整个 ConcurrentHashMap 由一个个 Segment 组成,Segment 代表”部分“或”一段“的意思,所以很多地方都会将其描述为分段锁。,需要的朋友可以参考下2019-06-06SpringBoot加载不出来application.yml文件的解决方法
这篇文章主要介绍了SpringBoot加载不出来application.yml文件的解决方法,文中通过示例代码讲解的非常详细,对大家的学习或者工作有一定的帮助,需要的朋友跟着小编来一起来学习吧2023-12-12java ssm框架的controller实现向页面传递参数
这篇文章主要介绍了java ssm框架的controller实现向页面传递参数,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-05-05
最新评论