我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql中 ${param}与#{param}使用区别

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql中 ${param}与#{param}使用区别

${param}传递的参数会被当成sql语句中的一部分,比如传递表名,字段名

例子:(传入值为id)

order by ${param} 

则解析成的sql为:

order by id

#{parm}传入的数据都当成一个字符串,会对自动传入的数据加一个双引号

例子:(传入值为id)

select * from table where name = #{param}

则解析成的sql为:

select * from table where name = "id"

为了安全,能用#的地方就用#方式传参,这样可以有效的防止sql注入攻击

sql注入简介

直接上了百度的例子,感觉一看就清晰明了

某个网站的登录验证的SQL查询代码为:


strSQL = "SELECT * FROM users WHERE (name = '" + userName + "') and (pw = '"+ passWord +"');"

恶意填入
userName = "1' OR '1'='1";与passWord = "1' OR '1'='1";时,将导致原本的SQL字符串被填为
strSQL = "SELECT * FROM users WHERE (name = '1' OR '1'='1') and (pw = '1' OR '1'='1'); "
也就是实际上运行的SQL命令会变成下面这样的strSQL = "SELECT * FROM users;"

这样在后台帐号验证的时候巧妙地绕过了检验,达到无账号密码,亦可登录网站。所以SQL注入攻击被俗称为黑客的填空游戏。

到此这篇关于mysql中 ${param}与#{param}使用区别的文章就介绍到这了,更多相关mysql中 ${param}与#{param}区别内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql中 ${param}与#{param}使用区别

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql中 ${param}与#{param}使用区别

${param}传递的参数会被当成sql语句中的一部分,比如传递表名,字段名 例子:(传入值为id) order by ${param} 则解析成的sql为: order by id#{parm}传入的数据都当成一个字符串,会对自动传入的数
2022-05-24

mysql中replaceinto与insertinto区别

本文主要介绍了mysql中replaceinto与insertinto区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-18

Python中“is”与“==”的使用区别

“is”与“==”的主要区别:1、功能的区别;2、使用场景的区别;3、比较结果的区别;4、性能的区别;“is”通常用于比较变量与单例值(如None)的关系,或者比较两个同构对象是否为同一对象,而“==”通常用于比较两个变量的值是否相等,不考虑它们在内存中的位置。
Python中“is”与“==”的使用区别
2023-10-29

在 MySQL 中使用 INT(1) 与 TINYINT(1) 有区别吗?

括号中使用的数字1仅用于宽度显示。 INT(1)和TINYINT(1)不影响存储。TINYINT占用1个字节,这意味着它的范围是-128到+127,而int占用4个字节;它的范围是 -2147483648 到 +2147483647要了解宽
2023-10-22

mysql中null与(null的区别

mysql 中 null 和 (null) 区别如下:null 表示未知值,而 (null) 表示明确空值。null 不占用存储空间,而 (null) 占用一个字节。null 不等于任何值,而 (null) 等于它自己。null 用于表示缺
mysql中null与(null的区别
2024-05-01

mysql中null与(null)的区别

在 mysql 中,null 代表空值,不占用空间,而 (null) 是空字符串值,占用 1 字节空间。它们的区别包括:存储方式不同、比较方式不同、插入方式不同、聚合函数处理方式不同、索引使用不同。MySQL 中 NULL 与 (NULL)
mysql中null与(null)的区别
2024-05-01

python3中sort和sorted使用与区别

这篇文章比较了Python中的sort()和sorted()函数,用于对列表排序。sort()直接修改原列表,无需返回值,默认升序排序。sorted()返回一个排序后的新列表,不修改原列表,可自定义排序规则。sort()效率更高,适用于永久性修改列表;sorted()适用于临时排序或自定义规则。
python3中sort和sorted使用与区别
2024-04-02

mysql中replace into与insert into区别

replace into 遇到主键或唯一索引冲突时,会先删除数据,再插入新数据insert into 遇到主键或唯一索引冲突时,会直接报错,不插入数据案例:新建一个test表,三个字段,id,title,uid, id是自增的主键,u
2023-01-18

MySQL关键字IN与EXISTS的使用与区别详解

目录1. IN & NOT IN1.1 基本使用1.2 工作原理1.2.1 静态值列表的 IN 语句1.2.2 子查询的 IN 语句1.3 相关优化2. EXISTS & NOT EXISTS2.1 基本使用2.2 工作原理2.3 相关优化
MySQL关键字IN与EXISTS的使用与区别详解
2024-09-05

mysql中datatime与timestamp有什么区别

这篇文章主要介绍了mysql中datatime与timestamp有什么区别,编程网小编觉得不错,现在分享给大家,也给大家做个参考,一起跟随编程网小编来看看吧!mysql中有三种日期类型:date(年-月-日)create table te
2023-06-06

MySQL 中 SELECT DISTINCT 与 GROUP BY 的区别?

SELECT DISTINCT 可用于给出不同的值。用它来删除重复的记录并它也可以与聚合函数一起使用。例如:MAX、AVG等。这个都可以应用在单个列上。现在,我正在创建一个表以对列使用 SELECT DISTINCT。创建一个表CRE
2023-10-22

mysql中 datatime与timestamp的区别说明

mysql中有三种日期类型: date(年-月-日) create table test(hiredate date); datetime(日期时间类型) create table test(hiredate datetime) times
2022-05-27

编程热搜

目录