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>

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

相关推荐
渣哥3 分钟前
原来 Java 里线程安全集合有这么多种
java
间彧10 分钟前
Spring Boot集成Spring Security完整指南
java
间彧34 分钟前
Spring Secutiy基本原理及工作流程
java
Java水解2 小时前
JAVA经典面试题附答案(持续更新版)
java·后端·面试
洛小豆4 小时前
在Java中,Integer.parseInt和Integer.valueOf有什么区别
java·后端·面试
前端小张同学4 小时前
服务器上如何搭建jenkins 服务CI/CD😎😎
java·后端
ytadpole4 小时前
Spring Cloud Gateway:一次不规范 URL 引发的路由转发404问题排查
java·后端
华仔啊4 小时前
基于 RuoYi-Vue 轻松实现单用户登录功能,亲测有效
java·vue.js·后端
程序员鱼皮5 小时前
刚刚 Java 25 炸裂发布!让 Java 再次伟大
java·javascript·计算机·程序员·编程·开发·代码