MyBatis入门(三)——模式查询的两种方式并#{}和${}的区别

(一)传参时给定模糊查询的标识

我们在配置文件中没有加入%来作为模糊查询的条件,所以在传入字符串实参时,就需要给定模糊查询的标识%

  1. 在持久层接口中添加模糊查询方法
    /**
    * 根据名称模糊查询
    * @param username
    * @return
    */
    List<User> findByName(String username);
    
  2. 映射配置文件中配置
    <select id ="findByName" resultType="com.test.domain.User" parameterType="String">
    	select * from user where username like #{username}
    </select>
    
  3. 测试
    @Test
    public void testFindByName(){
    	List<User> users = userDao.findByName("%王%");
    	for(User user : users){
    		System.out.println(user);
    	}
    }
    

在控制台的执行语句

(二)配置文件中配置

  1. 更改配置文件。
    将上面的#{}占位符,改成了${value}
    <select id ="findByName" resultType="com.test.domain.User" parameterType="String">
    	select * from user where username like '%${value}%'
    </select>
    
  2. 测试
    @Test
    public void testFindByName(){
    	List<User> users = userDao.findByName("王");
    	for(User user : users){
    		System.out.println(user);
    	}
    }
    

在控制台的执行语句

【总结】

这两种方式的实现效果是一样的,但执行的语句是不一样的


#{}和${}的区别

#{}
表示一个占位符。通过#{}可以实现preparedStatement向占位符中设置值,自动进行java类型和jdbc类型转换,可以有效防止sql注入。#{}可以接收简单类型值或POJO属性值。如果preparedStatement传输单个简单类型值,#{}括号中可以是value或其他名称。

${}

表示拼接sql串;通过${}可以将parameterType传入的内容拼接在sql中且不进行jdbc类型转换${}可以接收简单类型值或pojo属性值。如果parameterType传输单个简单类型值,${}括号中只能是value。

意思是,配置文件中的名称只能叫value,不能换(如下)
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值