MyBatis_04(MyBatis获取“参数值”的两种方式)

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

MyBatis获取参数值的两种方式:${}#{}

${}的本质就是字符串拼接 , #{}的本质就是占位符赋值 

${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引号;但是#{}使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时,可以自动添加单引号

1-单个字面量类型的参数

(第一种情况:单个字面量类型的参数)

  • 若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>

2-多个字面量类型的参数

(第二种情况:多个字面量类型的参数)

  • 若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>

3-map集合类型的参数

原理;和 "多个字面量类型的参数" ,一样都是放在"Map中"

区别:一个是"java给我们的map"、"一个是我们自己写的map,自己定义Key,Value"

  • 若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>

//自己写的Map测试

@Test
    public void checkLoginByMap() {
        SqlSession sqlSession = SqlSessionUtils.getSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        Map<String,Object> map = new HashMap<>();
        map.put("username","admin111");
        map.put("password","123456");
        User user = mapper.checkLoginByMap(map);
        System.out.println(user);
    }

4-实体类类型的参数 (最常用的方式!!!)

  • 若mapper接口中的方法 "参数为实体类对象" 时此时可以使用${}和#{},通过访问实体类对象中的 "属性名" 获取属性值,注意${}需要手动加单引号

// #{}方式

<!--int insertUser(User user);-->
<insert id="insertUser">
	insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email})
</insert>

//因为需要传入一个 "实体类"
//在测试方法中 "new一个实体类"

@Test
    public void insertUser() {
        SqlSession sqlSession = SqlSessionUtils.getSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        User user = new User(null,"Tom","123456",12,"男","123@321.com");
        Integer integer = mapper.insertUser(user);
        System.err.println(integer);
    }

5-使用@Param标识参数

  • 可以通过@Param注解标识mapper接口中的方法参数,此时,会将这些参数放在map集合中

1-以 "@Param注解的value属性值" 为键,以参数为值;
//在mapper接口中写@Param

@Param注解的value属性值:  @Param("username") String username, @Param("password") String password)
2-以param1,param2…为键,以参数为值;
  • 只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号

// #{}方式

<!--User CheckLoginByParam(@Param("username") String username, @Param("password") String password);-->
    <select id="CheckLoginByParam" resultType="User">
        select * from t_user where username = #{username} and password = #{password}
    </select>

@Test
    public void checkLoginByParam() {
        SqlSession sqlSession = SqlSessionUtils.getSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        User admin = mapper.CheckLoginByParam("admin111", "123456");
        System.err.println(admin);
    }

6- 总结

  • 建议分成 "两种" 情况进行处理:

  • 1-实体类类型的参数

  • 2-使用@Param标识参数

posted on   陈嘻嘻-  阅读(21)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示