友情提示:此篇文章大约需要阅读 6分钟 41秒,不足之处请多指教,感谢你的阅读。
预处理
预处理是 MySQL 为了防止客户端频繁请求的一种技术,是对相同处理语句进行预先加载在 MySQL 中,将操作变量数据用占位符来代替,减少对 MySQL 的频繁请求,使得服务器高效运行。
在这里客户端并不是前台后台之间的 C/S 架构,而是后台程序对数据库服务器进行操作的 C/S 架构,这样就可以简要地理解了后台程序作为 Client 向 MySQL Server 请求并处理结果了。
普通 SQL 执行处理过程:在客户端准备 SQL 语句;
发送 SQL 语句到 MySQL 服务器;
在 MySQL 服务器执行该 SQL 语句;
服务器将执行结果返回给客户端。
预处理执行处理过程:将 SQL 拆分为结构部分与数据部分;
在执行 SQL 语句的时候,首先将前面相同的命令和结构部分发送给 MySQL 服务器,让 MySQL 服务器事先进行一次预处理(此时并没有真正的执行 SQL 语句);
为了保证 SQL 语句的结构完整性,在第一次发送 SQL 语句的时候将其中可变的数据部分都用一个数据占位符来表示;
然后把数据部分发送给 MySQL 服务端,MySQL 服务端对 SQL 语句进行占位符替换;
MySQL 服务端执行完整的 SQL 语句并将结果返回给客户端。
预处理优点预处理语句大大减少了分析时间,只做了一次查询(虽然语句多次执行);
绑定参数减少了服务器带宽,只需发送查询的参数,而不是整个语句;