gpt4 book ai didi

php - PDO 可以为多个查询重用相同的语句句柄吗?

转载 作者:行者123 更新时间:2023-11-28 23:49:12 25 4
gpt4 key购买 nike

我正在使用 PDO 访问我的数据库,并同时使用两个 while 循环和 fetch 进行循环,如下所示:

$DBH = new PDO('mysql:host=localhost;dbname=database;charset=utf8',$dblogin,$dbpass);
$sql = 'SELECT * FROM table';
$STH = $DBH->prepare($sql);
$STH->execute();

while ($bm_table = $STH->fetch(PDO::FETCH_ASSOC))
{
// SQL Query
$sql1 = 'QUERY HERE';
$STH1 = $DBH->prepare($sql1);
$STH1->execute();

// Loops through using different handle, but what if I used STH again?
while ($row = $STH1->fetch(PDO::FETCH_ASSOC))
{
SomeFunction($bm_table,$row);
}
}

正如您在上面看到的,我正在使用不同的语句句柄($STH$STH1 等),这有必要吗?或者我可以只对所有内容使用一个语句句柄吗?我使用多个句柄的原因是因为使用 $STH$bm_table 值在我获取 $row 时仍将被使用这不会改变 $bm_table 的值或停止提取工作吗?带 PDO 的 handle 如何工作?特别是在这种情况下,我有两个同时运行的获取循环使用相同的 PDO 连接。

所以我在这里寻找的主要内容是,如果我有两个同时运行的语句,当我继续使用相同的连接时使用不同的句柄是否重要?

最佳答案

$STHSTH1 不是语句句柄,它们只是 PHP 变量。如果您不再需要它的旧值,您可以重新分配一个变量。但是对于这段代码,您仍然需要旧值。

如果您将外层循环内的 $STH 分配给第二个 prepare() 调用返回的句柄,那么当它回到循环的顶部并且重新执行 $STH->fetch() 测试,它将尝试从第二个查询而不是第一个查询中获取。这将立即结束外循环,因为所有这些行都已读取。

您可以为重复的相同 查询重用一个语句句柄。这在查询带有参数时非常有用:

$stmt = $DBH->prepare("SELECT * FROM tablename WHERE id = :id");
$stmt->bindParam(':id', $id);
foreach ($id_array as $id) {
$stmt->execute();
$row = $stmt->fetch();
// do stuff with $row
}

关于php - PDO 可以为多个查询重用相同的语句句柄吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32917499/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com