当前位置: 首页 > 编程笔记 >

浅谈为什么要使用mybatis的@param

邵飞宇
2023-03-14
本文向大家介绍浅谈为什么要使用mybatis的@param,包括了浅谈为什么要使用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 来命名。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍浅谈互斥锁为什么还要和条件变量配合使用,包括了浅谈互斥锁为什么还要和条件变量配合使用的使用技巧和注意事项,需要的朋友参考一下 mutex体现的是一种竞争,我离开了,通知你进来。 cond体现的是一种协作,我准备好了,通知你开始吧。 互斥锁一个明显的缺点是它只有两种状态:锁定和非锁定。而条件变量通过允许线程阻塞和等待另一个线程发送信号的方法弥补了互斥锁的不足,它常和互斥锁一起配合使用。

  • 本文向大家介绍浅谈MyBatis 事务管理,包括了浅谈MyBatis 事务管理的使用技巧和注意事项,需要的朋友参考一下 1. 运行环境 Enviroment 当 MyBatis 与不同的应用结合时,需要不同的事务管理机制。与 Spring 结合时,由 Spring 来管理事务;单独使用时需要自行管理事务,在容器里运行时可能由容器进行管理。 MyBatis 用 Enviroment 来表示运行环境,

  • 本文向大家介绍浅谈java中null是什么,以及使用中要注意的事项,包括了浅谈java中null是什么,以及使用中要注意的事项的使用技巧和注意事项,需要的朋友参考一下 1.null既不是对象也不是一种类型,它仅是一种特殊的值,你可以将其赋予任何引用类型,你也可以将null转化成任何类型,例如: Integer i=null; Float f=null; String s=null; 但是不能把nu

  • 本文向大家介绍浅谈MyBatis通用Mapper实现原理,包括了浅谈MyBatis通用Mapper实现原理的使用技巧和注意事项,需要的朋友参考一下 本文会先介绍通用 Mapper 的简单原理,然后使用最简单的代码来实现这个过程。 基本原理 通用 Mapper 提供了一些通用的方法,这些通用方法是以接口的形式提供的,例如。 接口和方法都使用了泛型,使用该通用方法的接口需要指定泛型的类型。通过 Jav

  • 本文向大家介绍为什么要使用 kafka,为什么要使用消息队列?相关面试题,主要包含被问及为什么要使用 kafka,为什么要使用消息队列?时的应答技巧和注意事项,需要的朋友参考一下 缓冲和削峰:上游数据时有突发流量,下游可能扛不住,或者下游没有足够多的机器来保证冗余,kafka在中间可以起到一个缓冲的作用,把消息暂存在kafka中,下游服务就可以按照自己的节奏进行慢慢处理。 解耦和扩展性:项目开始的

  • 本文向大家介绍谈一下,为什么tcp为什么要建立连接?相关面试题,主要包含被问及谈一下,为什么tcp为什么要建立连接?时的应答技巧和注意事项,需要的朋友参考一下 考察点:TCP   保证可靠传输。