Java笔记--Mybatis中的#和$--2021-05-13

13 篇文章 0 订阅


在mapper文件中,我们传参时可以看到一直在使用 #{ } ,它是什么?跟 ${ } 有什么区别?现在讲解记录。

#:占位符

告诉 mybatis 使用实际的参数值代替。并使用 PrepareStatement 对象执行 sql 语句, #{…}代替sql 语句的“?”。这样做更安全,更迅速,通常也是首选做法,

转为 MyBatis 的执行是:

	String sql=” select id,name,email,age from student where id=?;
	PreparedStatement ps = conn.prepareStatement(sql);
	// 参数1代表第一个?,1005代表?的值
	ps.setInt(1,1005);

解释:
where id=? 就是 where id=#{studentId}
ps.setInt(1,1005) , 1005 会替换掉 #{studentId}

$: 字符串替换

告诉 mybatis 使用 $ 包含的“字符串”替换所在位置。使用 Statement 把 sql 语句和 ${} 的内容连接起来。主要用在替换表名,列名,不同列排序等操作。

例子

例1:分别使用id,email列查询Student

	//接口方法:
	Student findById(int id);
	Student findByEmail(String email)
	
	//mapper 文件:
	<select id="findById" resultType="com.bjpowernode.domain.Student">
 		select * from student where id=#{studentId}
	</select>
	
	<select id="findByEmail" resultType="com.bjpowernode.domain.Student">
 		select * from student where email=#{stuentEmail}
	</select>
	
	//测试方法:
	@Test
	public void testFindStuent(){
	 Student student1 = studentDao.findById(1002);
	 System.out.println("findById:"+student1);
	 Student student2 = studentDao.findByEmail("zhou@126.net");
	 System.out.println("findByEmail:"+student2);
	}
	

例2:通用方法,使用不同列作为查询条件

	//接口方法:
	Student findByDiffField(@Param("col") String colunName,@Param("cval") Object 
	value);
	
	//mapper 文件:
	<select id="findByDiffField" resultType="com.bjpowernode.domain.Student">
	 select * from student where ${col} = #{cval}
	</select>
	
	//测试方法:
	@Test
	public void testFindDiffField(){
	 Student student1 = studentDao.findByDiffField("id",1002);
	 System.out.println("按 id 列查询:"+student1);
	 Student student2 = studentDao.findByDiffField("email","zhou@126.net");
	 System.out.println("按 email 列查询:"+student2);
	}

总结

# 和 $区别

  1. #使用 ?在sql语句中做站位的, 使用PreparedStatement执行sql,效率高
  2. #能够避免sql注入,更安全。
  3. $不使用占位符,是字符串连接方式,使用Statement对象执行sql,效率低
  4. $有sql注入的风险,缺乏安全性。
  5. $:可以替换表名或者列名
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张德帅-001

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值