gpt4 book ai didi

PHP PDO foreach 循环提供额外的表输出

转载 作者:行者123 更新时间:2023-11-29 02:46:30 25 4
gpt4 key购买 nike

希望有人能解决这个问题。

我有以下 MySQL 查询:

$sql = $db->prepare("SELECT 
dienaren.id,
dienaren.achternaam_minister,
dienaren.email_minister,
dienaren.gemeente,
users.achternaam,
users.email,
users.periode_van,
users.periode_tot
FROM dienaren
LEFT JOIN users
ON dienaren.id = users.minister_id
WHERE users.periode_tot < DATE_ADD(CURDATE(), INTERVAL + 31 DAY)
ORDER BY dienaren.id,users.periode_tot ASC");
$sql->execute();

这给了我 29 行的结果(我检查是正确的)

现在我想使用一种循环来显示一个表,其中 A 具有与查询对应的 x 行。 B 人、C 人等也是如此。

这是当前输出的屏幕截图:

screenshot

如您所见,此人有 2 条真实记录。但它显示的是两个列表而不是一个总列表。

这是生成此表的代码:

<?php
$count = $sql->rowCount();
echo '<p>Total result SQL query: '.$count.'</p>';
?>

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>

<?php foreach($sql->fetchAll(PDO::FETCH_OBJ) as $voorganger): ?>

<div><strong>Person ID: <?= $voorganger->id;?></strong></div>
<div>Is in control of the following users:</div>

<table>
<tr>
<th>Voorletter(s)</th>
<th>Periode Tot</th>
<th>Status</th>
</tr>

<?php
$query = $db->prepare("SELECT * FROM users WHERE minister_id = '{$voorganger->id}' AND periode_tot < DATE_ADD(CURDATE(), INTERVAL + 31 DAY) ORDER BY minister_id ASC");
$query->execute();

foreach($query->fetchAll(PDO::FETCH_OBJ) as $user) : ?>

<?php $date = new DateTime($user->periode_tot); ?>

<tr style="background:rgba(244, 65, 55, 0.35);">
<td><?= $user->voorletters; ?></td>
<td><?= $date->format('d-m-Y'); ?></td>

<?php if (dateDifference($user->periode_tot,$currentdate) > 0 && dateDifference($user->periode_tot,$currentdate) <= 30) { ?>
<td>Verloopt over&nbsp;<?= dateDifference($user->periode_tot,$currentdate); ?>&nbsp;dagen</td>
<?php } else { ?>
<td>Verlopen</td>
<?php } ?>
</tr>

<?php endforeach; ?>

</table>
<hr>

<?php endforeach; ?>

</body>
</html>

希望想要帮助我的人清楚这一点。如果不只是让我知道解释更多。 (顺便说一句:我更改了表中的一些结果,因为它包含私有(private)的实际数据)

提前致谢。

编辑:

只是指出在数据库中我有一个 dienaren 表,它在 T2 上有很多关系(持有用户和一个名为 minister_id 的字段)

循环遍历用户表,例如。 5 个结果有一个表创建了 5 次,包含所有 5 个结果(zie 屏幕截图 2)enter image description here .相反,我想要的只是一张包含这 5 个结果的表格。我想我没有使用正确的循环功能,或者我没有正确使用它。

screenshot2

第二次编辑:

我采用了一种不同的方法,这让我接近了我的解决方案。我从 JOIN 查询更改为 SELECT * FROM T1。唯一的缺点是它还会显示所有结果为 0 的记录。那么,我如何预先阻止 T1 中的人员创建一个表,而 T2 中的查询没有结果?

(在这种情况下,ID:861 有 5 条记录,但 ID:862 没有记录,但也有一个空表。我想摆脱空表)

screenshot new situation

最佳答案

成功了:

foreach($sql->fetchAll(PDO::FETCH_OBJ) as $person):

$person_id = $person->id;

$query = $db->prepare("SELECT * FROM users WHERE person_id = '{$person_id}' AND periode_tot < DATE_ADD(CURDATE(), INTERVAL + 31 DAY)");
$query->execute();

$total = $query->rowCount();

if ($total > 0) {
?>
<div><?= $person_id; ?></div>
<div><?= $person->achternaam_person; ?></div>
<div><?= $person->gemeente; ?></div>

<table>
<tr>
<th>Gemeente</th>
<th>Achternaam(s)</th>
<th>Voorletter(s)</th>
<th>Periode Tot</th>
<th>Status</th>
<th>Email</th>
</tr>
<?php
while ($user = $query->fetch(PDO::FETCH_OBJ)) {
$date = new DateTime($user->periode_tot);
?>
<tr style="background:rgba(244, 65, 55, 0.35);">
<td><?= $user->gemeente; ?></td>
<td><?= $user->achternaam; ?></td>
<td><?= $user->voorletters; ?></td>
<td><?= $date->format('d-m-Y'); ?></td>
<td>Verloopt over&nbsp;<?= dateDifference($user->periode_tot,$currentdate); ?>&nbsp;dagen</td>
<td><?= $user->email; ?></td>
</tr>

<?php } } ?>

</table>

<?php endforeach; ?>

关于PHP PDO foreach 循环提供额外的表输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41452732/

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