Mybatis总结--传参二

#叫做占位符

Mybatis是封装的JDBC 增强版 内部还是用的jdbc

每遇到一个#号 这里就会变为?占位符

一个#{}就是对应一个问号 一个占位符

用这个对象执行sql语句没有sql注入的风险

八、多个参数**-使用@Param**

当 Dao 接口方法有多个参数,需要通过名称使用参数:
在方法形参前面加入@Param("自定义参数名 "),
mapper 文件使用#{自定义参数名}。

8.1、sql映射文件,StudentDao.xml:
java 复制代码
  <select id = "selectMulitParam" resultType="com.lifang.domain.Student">
        select id,name,email,age from student where name = #{myname} or age = #{myage}
  </select>
8.2、StudentDao接口:
java 复制代码
   public List<Student> selectMulitParam(@Param("myname") String name,
                                         @Param("myage") Integer age);
8.3、测试代码及结果:
java 复制代码
    @org.junit.Test
    public void test04(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        StudentDao dao = sqlSession.getMapper(StudentDao.class);
        List<Student> students = dao.selectMulitParam("李四",23);
        students.forEach(student -> System.out.println(student));

    }

九、多个参数**-**使用对象

**使用 java 对象传递参数, java 的属性值就是 sql 需要的参数值。**灵活又方便

语法格式: #{ property属性名,javaType=java 数据类型的全限定名称,jdbcType=Mybatis定义的数据库中类型的名称 }

javaType, jdbcType 的类型 MyBatis 可以通过反射获取,一般不需要设置。

常用格式 #{ property }

9.1、代表数据的实体类:
java 复制代码
public class QueryParam {
    private String queryName;
    private Integer queryAge;
9.2、sql映射文件,StudentDao.xml:
java 复制代码
 <select id = "selectMultiObject" resultType="com.lifang.domain.Student">
        select id,name,email,age from student where name = #{queryName} or age =#{queryAge}
 </select>
9.3、StudentDao接口:
java 复制代码
 public List<Student> selectMultiObject(QueryParam queryParam);
9.4、测试代码及结果:
java 复制代码
   @org.junit.Test
    public void test05(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        StudentDao dao = sqlSession.getMapper(StudentDao.class);
        QueryParam queryParam = new QueryParam("王五",23);
        List<Student> students = dao.selectMultiObject(queryParam);
        students.forEach(student -> System.out.println(student));
    }
9.5、总结:

++所以我们传参的时候灵活一点,参数可以是现成的java对象,如Student;或者用自定义的java对象QueryParam:++

java 复制代码
public List<Student> selectMultiObject(QueryParam queryParam);

public List<Student> selectMultiStudent(Student student);
XML 复制代码
    <select id = "selectMultiObject" resultType="com.lifang.domain.Student">
        select id,name,email,age from student where name = #{queryName} or age =#{queryAge}
    </select>


    <select id = "selectMultiStudent" resultType = "com.lifang.domain.Student">
        select id,name,email,age from student where  name = #{name} or age = #{age}
    </select>

十、多个参数**-**使用对象

相关推荐
MY_TEUCK2 小时前
【Java 后端】SpringBoot 登录认证与会话跟踪实战(JWT + Filter/Interceptor)
java·开发语言·spring boot
今天长肉了吗2 小时前
银行风控项目踩坑实录:指标跑了6小时,风险评分全挂了
java
QQ2422199792 小时前
基于python+微信小程序的家教管理系统_mh3j9
开发语言·python·微信小程序
随读手机2 小时前
多式联运信息交互平台完整方案(2026版)
java·ai·eclipse·云计算·区块链
沐知全栈开发2 小时前
JavaScript 条件语句
开发语言
RSTJ_16252 小时前
PYTHON+AI LLM DAY THREETY-SEVEN
开发语言·人工智能·python
清水白石0083 小时前
《Python性能深潜:从对象分配开销到“小对象风暴”的破解之道(含实战与最佳实践)》
开发语言·python
Je1lyfish3 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午3 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
nj01283 小时前
Spring 循环依赖详解:三级缓存、早期引用、AOP 代理与懒加载
java·spring·缓存