【MYSQL】字符串拼接和参数化sql语句区别

总结:

参数化不是为了复用查询结果,

而是为了固定 SQL 结构,让解析和执行行为可预测;

同时通过语义隔离彻底消除 SQL 注入。

字符串拼接:

csharp 复制代码
var ids = string.Join(",", idList);

var sql = $@"
SELECT *
FROM a
WHERE a.id IN ({ids});
";
//生成sql可能是
SELECT *
FROM a
WHERE a.id IN (1,2,3,4,5,6,7,8,9,...);

参数化sql:

csharp 复制代码
var parameters = new List<MySqlParameter>();
var placeholders = new List<string>();

for (int i = 0; i < idList.Count; i++)
{
    var name = $"@id{i}";
    placeholders.Add(name);
    parameters.Add(new MySqlParameter(name, idList[i]));
}

var sql = $@"
SELECT *
FROM a
WHERE a.id IN ({string.Join(",", placeholders)});
";
//生成固态sql
SELECT *
FROM a
WHERE a.id IN (@id0,@id1,@id2,...);

在代码层面,虽然每次调用都是不同的sql,但是对于mysql数据库来说完全不一样。

上面给出的两个代码注释下面就是数据库接收到的sql模式,可以看到,参数化每次数据库接收的都是一样的。因此 参数化让数据库能够 复用 解析结构和执行计划,从而减少解析与优化的开销。 而拼接字符串每次都是不同的sql语句,需要重新解析。

另外拼接字符串会有注入的风险,但是参数化不会有。因为数据库在解析阶段只确认"占位符的位置和类型",并不会把参数值当成 SQL 语法来解析。

举个例子说明:

这是字符串拼接

csharp 复制代码
sql = "WHERE id IN (" + userInput + ")";
//如果用户输入
1) OR 1=1 --
//最终sql是
WHERE id IN (1) OR 1=1 --)

参数化

csharp 复制代码
WHERE id IN (?)
//输入
1) OR 1=1 --
//数据库看到
id = "1) OR 1=1 --"

数据库处理流程是:

1.先解析 SQL 结构

2.确认:? 是一个"值占位符"

3.SQL 语法树已经固定

4.再把参数值"绑定"为数据

完结撒花~

相关推荐
想摆烂的不会研究的研究生1 天前
每日八股——Redis(1)
数据库·经验分享·redis·后端·缓存
码熔burning1 天前
MySQL 8.0 新特性爆笑盘点:从青铜到王者的骚操作都在这儿了!(万字详解,建议收藏)
数据库·mysql
猫头虎1 天前
2025最新OpenEuler系统安装MySQL的详细教程
linux·服务器·数据库·sql·mysql·macos·openeuler
哈库纳玛塔塔1 天前
放弃 MyBatis,拥抱新一代 Java 数据访问库
java·开发语言·数据库·mybatis·orm·dbvisitor
@LetsTGBot搜索引擎机器人1 天前
2025 Telegram 最新免费社工库机器人(LetsTG可[特殊字符])搭建指南(含 Python 脚本)
数据库·搜索引擎·机器人·开源·全文检索·facebook·twitter
计算机毕设VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue动物园管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
冉冰学姐1 天前
SSM校园排球联赛管理系统y513u(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架应用·开题报告、
Tony Bai1 天前
【分布式系统】03 复制(上):“权威中心”的秩序 —— 主从架构、一致性与权衡
大数据·数据库·分布式·架构
wb043072011 天前
SQL工坊不只是一个ORM框架
数据库·sql
至善迎风1 天前
Redis完全指南:从诞生到实战
数据库·redis·缓存