草庐IT

php - 释放 PDO 准备好的语句 (DEALLOCATE PREPARE)

coder 2023-06-12 原文

是否应该在使用后释放 PDO 准备语句?如果是这样,怎么办?具体来说,我问的是 MySQL - 你怎么能,你应该调用 DEALLOCATE PREPARE虽然 PDO。 (编辑:澄清一下,这个问题不是指模拟准备,而是真正的准备。)

此外 - 这会释放结果集(当很大时)吗?

解释:

我看到的代码是

$stmnt = $db->prepare($sql);
$stmnt->execute($aParams);
$stmnt = null;

这让我想知道它的作用、时间以及是否 f unset($stmnt); 会有所不同?

手册中指出

When the query is prepared, the database will analyze, compile and optimize its plan for executing the query. [...] By using a prepared statement the application avoids repeating the analyze/compile/optimize cycle.

这倾向于建议你应该取消分配语句,而 MySQL 有这个能力。所以,

  1. 你能调用DEALLOCATE PREPARE吗,如何调用
  2. 你应该这样做吗?
  3. 谁能确认将语句设置为 null(或取消设置语句)对 mysql_ 和 mysqli_ 的作用与“free_result”相同?
  4. 它是立即发生,还是等待垃圾收集器启动?

为了完整起见,另一个 SO question引用 mysqli_() 的“free_result”和“close”函数表明释放语句实际上会增加时间(除非您使用大量内存并且需要空间)。但是“free_result”不同于让 SQL 服务器免于缓存准备好的语句。

最佳答案

Should PDO prepared statements be freed up after use? And if so, how?

在 MySQL 的上下文中?不,为什么?

PDO emulates prepared statements by default .这意味着 PDO 本身会执行参数替换、转义等操作,并在线下发送 SQL block ,而不是使用 native 准备好的语句。

虽然您可以打开它,但您仍然不需要明确关闭句柄除非您也在使用unbuffered queries .仅让语句句柄超出范围或将其设置为 null 不会关闭游标。同样,这只有在您使用无缓冲查询时才有意义。如果不是,那么让它超出范围或将其设置为 null 就足以干净地关闭句柄。

您还链接到 DEALLOCATE PREPARE .该语法手动调用PREPARE时需要。使用 SQL 字符串。这是与 MySQL C-level API-based prepared statements 完全独立的操作。 ,这是 PDO_MYSQL 正在使用的。 (好吧,也许你正在使用 mysqlnd,但实际上是一样的。)

关于php - 释放 PDO 准备好的语句 (DEALLOCATE PREPARE),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13559239/

有关php - 释放 PDO 准备好的语句 (DEALLOCATE PREPARE)的更多相关文章

  1. ruby - 如何在 Ruby 中向现有方法定义添加语句 - 2

    我注意到类定义,如果我打开classMyClass,并在不覆盖的情况下添加一些东西我仍然得到了之前定义的原始方法。添加的新语句扩充了现有语句。但是对于方法定义,我仍然想要与类定义相同的行为,但是当我打开defmy_method时似乎,def中的现有语句和end被覆盖了,我需要重写一遍。那么有什么方法可以使方法定义的行为与定义相同,类似于super,但不一定是子类? 最佳答案 我想您正在寻找alias_method:classAalias_method:old_func,:funcdeffuncold_func#similartoca

  2. ruby - ruby 乘法语句中星号中断语法前的空格 - 2

    在添加一些空格以使代码更具可读性时(与上面的代码对齐),我遇到了这个:classCdefx42endendm=C.new现在这将给出“错误数量的参数”:m.x*m.x这将给出“语法错误,意外的tSTAR,期待$end”:2/m.x*m.x这里的解析器到底发生了什么?我使用Ruby1.9.2和2.1.5进行了测试。 最佳答案 *用于运算符(42*42)和参数解包(myfun*[42,42])。当你这样做时:m.x*m.x2/m.x*m.xRuby将此解释为参数解包,而不是*运算符(即乘法)。如果您不熟悉它,参数解包(有时也称为“spl

  3. ruby - 有没有办法从 ruby​​ case 语句中访问表达式? - 2

    我想从then子句中访问c​​ase语句表达式,即food="cheese"casefoodwhen"dip"then"carrotsticks"when"cheese"then"#{expr}crackers"else"mayo"end在这种情况下,expr是食物的当前值(value)。在这种情况下,我知道,我可以简单地访问变量food,但是在某些情况下,该值可能无法再访问(array.shift等)。除了将expr移出到局部变量然后访问它之外,是否有直接访问caseexpr值的方法?罗亚附注我知道这个具体示例很简单,只是一个示例场景。 最佳答案

  4. ruby - 在好的 Ruby 代码中没有注释是否被认为是可以接受的? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。Improvethisquestion我审查了一些用Ruby编写的专业代码,没有发现任何评论。代码读起来相当清晰,但没有self记录。我应该期望专业编写的Ruby代码有注释吗?或者,是否有一些Ruby原则认为注释不是必需的?

  5. Ruby-vips 图像处理库。有什么好的使用示例吗? - 2

    我对图像处理完全陌生。我对JPEG内部是什么以及它是如何工作一无所知。我想知道,是否可以在某处找到执行以下简单操作的ruby​​代码:打开jpeg文件。遍历每个像素并将其颜色设置为fx绿色。将结果写入另一个文件。我对如何使用ruby​​-vips库实现这一点特别感兴趣https://github.com/ender672/ruby-vips我的目标-学习如何使用ruby​​-vips执行基本的图像处理操作(Gamma校正、亮度、色调……)任何指向比“helloworld”更复杂的工作示例的链接——比如ruby​​-vips的github页面上的链接,我们将不胜感激!如果有ruby​​-

  6. ruby - 在 Ruby 的 if 语句中检查 bash 命令 - 2

    如何在Ruby的if语句中检查bash命令的返回值(true/false)。我想要这样的东西,if("/usr/bin/fswscell>/dev/null2>&1")has_afs="true"elsehas_afs="false"end它会提示以下错误含义,它总是返回true。(irb):5:warning:stringliteralincondition正确的语法是什么?更新:/usr/bin/fswscell寻找afs安装和运行状态。它会抛出这样的字符串,Thisworkstationbelongstocell如果afs没有运行,命令以状态1退出 最

  7. ruby - 变量赋值后的 if 语句 - 有多常见? - 2

    我最近与一位同事讨论了以下Ruby语法:value=ifa==0"foo"elsifa>42"bar"else"fizz"end我个人并没有看到太多这种逻辑,但我的同事指出,这实际上是一种相当普遍的Rubyism。我试着用谷歌搜索这个主题,但没有找到任何文章、页面或SO问题来讨论它,这让我相信这可能是一种非常实际的技术。然而,另一位同事发现语法令人困惑,而是将上面的逻辑写成这样:ifa==0value="foo"elsifa>42value="bar"elsevalue="fizz"end缺点是value=的重复声明和隐式elsenil的丢失,如果我们想使用它的话。这也感觉它与Ruby

  8. ruby - 当你有一个没有参数的 case 语句并且 when 子句是 lambda 时会发生什么? - 2

    这段代码没有像我预期的那样执行:casewhen->{false}then"why?"else"ThisiswhatIexpect"end#=>"why?"这也不是casewhen->(x){false}then"why?"else"ThisiswhatIexpect"end#=>"why?"第一个then子句在两种情况下都被执行,这意味着我提供给when子句的lambda没有被调用。我知道无论when子句的主题是什么,都应该调用大小写相等运算符===。我想知道当没有为case提供参数时,===的另一边会发生什么。我在想它可能是nil,但它不可能是:->{false}===nil#=>

  9. ruby - 防止SQL注入(inject)/好的Ruby方法 - 2

    Ruby中防止SQL注入(inject)的好方法是什么? 最佳答案 直接使用ruby?使用准备好的语句:require'mysql'db=Mysql.new('localhost','user','password','database')statement=db.prepare"SELECT*FROMtableWHEREfield=?"statement.execute'value'statement.fetchstatement.close 关于ruby-防止SQL注入(inject

  10. ruby-on-rails - 什么是好的代码测试比率? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。Improvethisquestion我正在使用RSpec编写测试。您认为什么是好的代码测试比率?

随机推荐