ceacer 2 已发布 1月28号 分享 已发布 1月28号 引言:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。 MyBatis的主要特性之一:动态sql,在 mapper 中定义的参数传到 xml 中之后,在查询之前, mybatis 会对其进行动态解析。#{}以及${}正是为mybatis提供的两种动态sql方法。 一、#{}以及${}两者的区别 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'; 评论链接 在其他网站上分享 更多分享选项...
推荐帖
创建账户或登录以发表评论
您需要成为会员才能发表评论
创建一个帐户
在我们的社区注册一个新账户。很简单!
注册新账户登入
已有账户?在此登录
立即登录