您当前的位置:首页 > 互联网教程

PHP 使用 Mysqli 的 prepare 语句有什么好处

发布时间:2025-05-14 06:22:08    发布人:远客网络

PHP 使用 Mysqli 的 prepare 语句有什么好处

一、PHP 使用 Mysqli 的 prepare 语句有什么好处

(2)执行一些查询优化步骤只有一次

(3)通过二进制协议发送参数比送他们为ASCII文本更有效

比如DATE,对于准备之后,发送日期只用3个字节;如果没有准备,日期必须以字符串的形式发送,需要数据库方再解析,这样需要发送10个字节。

(4)只有参数(不是整个查询文本)需要为每个执行要发送

(5)的MySQL直接存储parameteres到服务器上的缓冲区

(6)安全性也有帮助,就没有必要逃避或引用值。

(1)本地到一个连接,以便另一个连接不能再使用

(2)不能使用MySQL查询缓存(5.1版本之前)

(3)不总是更有效,如果你使用它只有一次

(4)存储函数中不能使用(存储过程是可以的)

(5)有可能会导致“泄漏”如果你忘记释放它

二、mysql 存储过程 是什么意思

存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。

一个存储过程是一个可编程的函数,它在数据库中创建并保存。它可以有SQL语句和一些特殊的控制结构组成。当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的。数据库中的存储过程可以看做是对编程中面向对象方法的模拟。它允许控制数据的访问方式。

存储过程增强了SQL语言的功能和灵活性。存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。

存储过程允许标准组件是编程。存储过程被创建后,可以在程序中被多次调用,而不必重新编写该存储过程的SQL语句。而且数据库专业人员可以随时对存储过程进行修改,对应用程序源代码毫无影响。

存储过程能实现较快的执行速度。如果某一操作包含大量的Transaction-SQL代码或分别被多次执行,那么存储过程要比批处理的执行速度快很多。因为存储过程是预编译的。在首次运行一个存储过程时查询,优化器对其进行分析优化,并且给出最终被存储在系统表中的执行计划。而批处理的Transaction-SQL语句在每次运行时都要进行编译和优化,速度相对要慢一些。

存储过程能过减少网络流量。针对同一个数据库对象的操作(如查询、修改),如果这一操作所涉及的Transaction-SQL语句被组织程存储过程,那么当在客户计算机上调用该存储过程时,网络中传送的只是该调用语句,从而大大增加了网络流量并降低了网络负载。

存储过程可被作为一种安全机制来充分利用。系统管理员通过执行某一存储过程的权限进行限制,能够实现对相应的数据的访问权限的限制,避免了非授权用户对数据的访问,保证了数据的安全。

CREATE PROCEDURE过程名([过程参数[,...]])

END

存储过程根据需要可能会有输入、输出、输入输出参数,这里有一个输出参数s,类型是int型,如果有多个参数用","分割开。

存储过程根据需要可能会有输入、输出、输入输出参数,这里有一个输出参数s,类型是int型,如果有多个参数用","分割开。

过程体的开始与结束使用BEGIN与END进行标识。

注意:MySQL在5.0以前并不支持存储过程

三、sql中declare是什么意思

sql中declare是声明的意思,就是声明变量的,这个一般是用在函数和存储过程中的。比如说,这个存储过程是,只要你把学号输入进来,就能查询这个学生的班级。那么在这个存储过程里面,学号就是参数。你给什么学号,它就返回给你相应的班级。又或者你也可以做成,只要你输入学号,这个存储过程就会将这个学生删除。

mysql存储过程中,定义变量有两种方式:

1.使用set或select直接赋值,变量名以@开头.

可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。

2.以 DECLARE关键字声明的变量,只能在存储过程中使用,称为存储过程变量,例如:

主要用在存储过程中,或者是给存储传参数中。

在调用存储过程时,以DECLARE声明的变量都会被初始化为 NULL。而会话变量(即@开头的变量)则不会被再初始化,在一个会话内,只须初始化一次,之后在会话内都是对上一次计算的结果,就相当于在是这个会话内的全局变量。

在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。

有的时候在查询更新数据库的时候,需要多条语句的查询,因此需要多次修改

declare可以满足多次执行,但数据只修改一次。

declare@local_variable data_type

DECLARE:定义变量,变量第一个字母是“@”

可以使用set和select对变量进行赋值,

在sql语句中就可以使用@local_variable来调用变量

声明中可以提供值,否则声明之后所有变量将初始化为NULL。