MyBatis中使用$和井号有什么具体区别?有哪些最佳实践?

引言:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。

MyBatis的主要特性之一:动态sql,在 mapper 中定义的参数传到 xml 中之后,在查询之前, mybatis 会对其进行动态解析。#{}以及${}正是为mybatis提供的两种动态sql方法。

MyBatis中使用$和井号有什么具体区别?有哪些最佳实践?

一、#{}以及${}两者的区别

1、防注入方面

  • #{}:很大程度上能防止sql 注入
  • ${}:不能防止sql 注入

2、符号类型方面

  • #{}:参数占位符,即预编译
  • ${} :字符串替换符,即SQL拼接

3、参数替换位置方面

DBMS:数据库管理系统(Database Management System)是一种操纵和管理数据库的大型软件,是用于建立、使用和维护数据库,简称DBMS。它对数据库进行统一的管理和控制,以保证数据库的安全性和完整性。用户通过DBMS访问数据库中的数据,数据库管理员也通过DBMS进行数据库的维护工作。它提供多种功能,可使多个应用程序和用户用不同的方法在同时或不同时刻去建立,修改和询问数据库。

  • #{}:变量替换是在DBMS 中
  • ${}:变量替换是在 DBMS 外

4、参数解析方面

  • #{}:将传入的数据都当成一个字符串,会对传入的变量自动加一个单引号。如:user_id = #{userId},如果传入的值是111,那么解析成sql时的值为user_id = ‘111’,如果传入的值是id,则解析成的sql为user_id = ‘id’。
  • ${}:将传入的参数直接显示生成在sql中,且不加任何引号。如:user_id = ${userId},如果传入的值是111,那么解析成sql时的值为user_id = 111 , 如果传入的值是id,则解析成的sql为user_id = id。

5、执行过程方面

  • #{}:编译好SQL后语句再去取值
  • ${}:取值以后再去编译SQL语句

6、多用#少用$(一般能用#的就不用$)

二、SQL具体解析

1、两者的流程

#{}:动态解析 -> 预编译 -> 执行
${}:动态解析 -> 编译 -> 执行

2、具体案例

根据用户名name查询用户表user数据,如果 name 的值为 luoxiang

2.1、SQL编写

#{}

select * from user where name = #{name};

${}

select * from user where name = ${name};

2.2、编译中处理

#{}:在预处理时,会把参数用一个占位符” ?” 代替,变成以下SQL

select * from user where name = ?;

${}:只是简单的字符串替换,在动态解析时变成以下SQL

select * from user where name = 'luoxiang';

当然了,最后的解析结果是一样的,都是

select * from user where name = 'luoxiang';

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至2705686032@qq.com 举报,一经查实,本站将立刻删除。原文转载: 原文出处:

(0)
云计算的头像云计算
上一篇 2024 年 8 月 21 日
下一篇 2024 年 8 月 21 日

相关推荐

发表回复

登录后才能评论

联系我们

400-900-3935

在线咨询: QQ交谈

邮件:cong@zun.com

工作时间:365天无休服务 24小时在线

添加微信