sql语句中的#{}占位符和${}占位符

#将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by “111”, 如果传入的值是id,则解析成的sql为order by “id”。

$将传入的数据直接显示生成在sql中。如:order by userid ,如果传入的值是111,那么解析成sql时的值为order by user_id, 如果传入的值是id,则解析成的sql为order by id。

#方式能够很大程度防止sql注入;$方式无法防止Sql注入。

$方式一般用于传入数据库对象,例如传入表名。

一般能用#的就别用$。MyBatis排序时使用order by 动态参数时需要注意,用$而不是#。

默认情况下,使用#{}格式的语法会导致MyBatis创建预处理语句属性并以它为背景设置安全的值(比如?)。这样做很安全,很迅速也是首选做法,有时你只是想直接在SQL语句中插入一个不改变的字符串。比如,像ORDER BY,你可以这样来使用:

ORDER BY ${columnName};

这里MyBatis不会修改或转义字符串。

重要:接受从用户输出的内容并提供给语句中不变的字符串,这样做是不安全的。这会导致潜在的SQL注入攻击,因此你不应该允许用户输入这些字段,或者通常自行转义并检查。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL语句占位符(?)用作参数的占位符。它的作用是在执行SQL语句之前,将具体的参数值绑定到占位符上,以便动态地构建SQL语句。通过使用占位符,可以避免直接将参数值嵌入到SQL语句,从而提高了SQL语句的安全性和可维护性。\[1\] 例如,在使用PreparedStatement执行SQL语句时,可以通过调用setString、setInt等方法来设置占位符的值。这样,每个占位符都可以与一个具体的参数值相关联,从而构建出完整的SQL语句。\[1\] 占位符的位置是按照它们在SQL语句出现的顺序进行关联的,而不是根据名称进行关联。这意味着如果SQL语句有多个相同的占位符,每个占位符都必须与一个绑定参数相关联。\[2\] 在动态PL/SQL,只有唯一的占位符才与USING子句的绑定参数按位置对应。如果一个占位符在PL/SQL出现多次,那么所有相同的占位符都只与USING语句的一个绑定参数相对应。\[2\] 占位符最常用于SQL语句的WHERE或HAVING子句,用作单个行或组的搜索条件的占位符。某些数据库还允许在表达式将参数用作占位符。通过使用占位符,可以实现动态的查询条件,提高SQL语句的灵活性和可重用性。\[3\] #### 引用[.reference_title] - *1* *3* [SQL占位符?的用法介绍~](https://blog.csdn.net/litrainy/article/details/84067808)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Oracle的动态SQL](https://blog.csdn.net/fw0124/article/details/6845790)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值