mybatis-获取参数值的方式

MyBatis获取参数值的两种方式(重点)

  • MyBatis获取参数值的两种方式:${}和#{}
  • ${}的本质就是字符串拼接,#{}的本质就是占位符赋值
  • ${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引号;但是#{}使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时,可以自动添加单引号

单个字面量类型的参数

  • 若mapper接口中的方法参数为单个的字面量类型,此时可以使用${}和#{}以任意的名称(最好见名识意)获取参数的值,注意${}需要手动加单引号
<!--User getUserByUsername(String username);-->
<select id="getUserByUsername" resultType="User">
	select * from t_user where username = #{username}
</select>
<!--User getUserByUsername(String username);-->
<select id="getUserByUsername" resultType="User">  
	select * from t_user where username = '${username}'  
</select>

多个字面量类型的参数

  • 若mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合中

    1. 以arg0,arg1...为键,以参数为值;
    2. 以param1,param2...为键,以参数为值;
  • 因此只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号。

  • 使用arg或者param都行,要注意的是,arg是从arg0开始的,param是从param1开始的

<!--User checkLogin(String username,String password);-->
<select id="checkLogin" resultType="User">  
	select * from t_user where username = #{arg0} and password = #{arg1}  
</select>
<!--User checkLogin(String username,String password);-->
<select id="checkLogin" resultType="User">
	select * from t_user where username = '${param1}' and password = '${param2}'
</select>

map集合类型的参数

  • 若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在map中只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
<!--User checkLoginByMap(Map<String,Object> map);-->
<select id="checkLoginByMap" resultType="User">
	select * from t_user where username = #{username} and password = #{password}
</select>
@Test
public void checkLoginByMap() {
	SqlSession sqlSession = SqlSessionUtils.getSqlSession();
	ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
	Map<String,Object> map = new HashMap<>();
	map.put("usermane","admin");
	map.put("password","123456");
	User user = mapper.checkLoginByMap(map);
	System.out.println(user);
}

实体类类型的参数

  • 若mapper接口中的方法参数为实体类对象时此时可以使用${}和#{},通过访问实体类对象中的属性名获取属性值,注意${}需要手动加单引号
<!--int insertUser(User user);-->
<insert id="insertUser">
	insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email})
</insert>
@Test
public void insertUser() {
	SqlSession sqlSession = SqlSessionUtils.getSqlSession();
	ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
	User user = new User(null,"Tom","123456",12,"男","123@321.com");
	mapper.insertUser(user);
}

整体测试类代码

package com.atguigu.mybatis.test;

import com.atguigu.mybatis.mapper.ParameterMapper;
import com.atguigu.mybatis.pojo.user;
import com.atguigu.mybatis.utils.sqlSessionUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

import java.sql.Connection;
import java.sql.DriverManager;
import java.util.HashMap;
import java.util.List;

public class ParameterMapperTest {
    @Test
    public void TestGetALLUser(){
        SqlSession sqlSession = sqlSessionUtils.GetSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        List allUser = mapper.getAllUser();
        allUser.forEach(user-> System.out.println(user));
    }

    /**
     * mybatis 获取参数值的两中方式:${}  和 #{}
     * 1:${}  本质就是字符串拼接
     * 2:#{} 本质就是占位符赋值
     *
     *   select * from t_user where username = #{username} // '${userame}'
     *
     *  可以通过${} 和 #{}以任意字符串来获取参数值,但是需要注意${}的单引号问题
     */
    @Test
    public void TestGetUserByUsername(){
        SqlSession sqlSession = sqlSessionUtils.GetSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        user admin = mapper.GetUserByUsername("张三");
        System.out.println(admin.toString());

    }

    /**
     * mapper接口方法的参数为多个时,、此时mybatis会将这些参数放到一个map集合中,以两种方式进行存储
     * a> 以arg0、arg1、、、、、、为健,以参数为值
     * b> 以param1,param2、、、、为健,以参数为值
     * 因此只需要通过#{} 和 ${} 以键的方式访问即可、但是需要注意的${}的单引号问题
     *
     */
    @Test
    public void testCheckLogin(){
        SqlSession sqlSession = sqlSessionUtils.GetSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        user user1= mapper.checkLogin("张三", "123456");
        System.out.println(user1.toString());
    }
    @Test
    public void testCheckLoginByMap(){
        SqlSession sqlSession = sqlSessionUtils.GetSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        HashMap<Object, Object> objectObjectHashMap = new HashMap<>();
        objectObjectHashMap.put("username","张三");
        objectObjectHashMap.put("password","123456");
        user user1 = mapper.checkLoginMap(objectObjectHashMap);
        System.out.println(user1);
    }
    /**
     * 4.mapper接口方法中的参数是一个实体类的类型的参数时,如何访问?
     * 只需要通过#{}和${}以属性的方式访问属性值即可,但是需要注意的${}的单引号问题
     */
    @Test
    public void testInsertUser(){
        SqlSession sqlSession = sqlSessionUtils.GetSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        user user = new user(null, "lisai", "123456", 23, "男", "wiseleer@163.com");
        int i = mapper.insertUser(user);
        System.out.println(i);
    }
    /**
     * 使用@param测试
     */
    @Test
    public void testcheckLoginByParam(){
        SqlSession sqlSession = sqlSessionUtils.GetSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        user user1= mapper.checkLoginByParam("张三", "123456");
        System.out.println(user1.toString());
    }
}
posted @ 2022-07-08 11:18  wiselee/  阅读(213)  评论(0编辑  收藏  举报