这是我在SO中的第一篇帖子,如果我打开一个现有的问题,我很抱歉。因为我在谷歌找不到结果。很抱歉,但我仍处于PHP PDO和学习阶段。
回到我的问题,目前我正在建立一个客户访问我妻子的日志,但我坚持结果。我有两个表,一个存储客户信息,另一个表存储访问详细信息。我在这里上传了测试表:SQL Fiddle
以下是我目前的编码,我正在使用PHP PDO 而
<?php
require_once 'dbconnect.php';
$p_id = $_GET['name'];
try {
$conn = new PDO("mysql:host=$host;dbname=$dbname", $username, $password);
$sql = "SELECT customer.fname, customer.lname, customer.gender, services.treatment, services.date
FROM customer LEFT JOIN services
ON customer.id = services.customer_id
WHERE customer.slug LIKE :id";
$q = $conn->prepare($sql);
$q->execute(array('id' => $p_id));
$q->setFetchMode(PDO::FETCH_ASSOC);
} catch (PDOException $pe) {
die("Could not connect to the database $dbname :" . $pe->getMessage());
}
?>
<!DOCTYPE html>
<html>
<head>
<title>Test</title>
</head>
<body>
<div id="container">
<h1>Customer Record</h1>
Name: <br />
Gender: <br />
<table class="table table-bordered table-condensed">
<thead>
<tr>
<th>Customer Name</th>
<th>Customer Gender</th>
<th>Treatment</th>
<th>Date</th>
</tr>
</thead>
<tbody>
<?php while ($r = $q->fetch()): ?>
<tr>
<td><?php echo htmlspecialchars($r['fname']), ' ', htmlspecialchars($r['lname'])?></td>
<td><?php echo htmlspecialchars($r['gender']); ?></td>
<td><?php echo htmlspecialchars($r['treatment']); ?></td>
<td><?php echo htmlspecialchars($r['date']); ?></td>
</tr>
<?php endwhile; ?>
</tbody>
</table>
<a href="search.html">Seach Again</a>
</body>
</div>
</html>
我实现了SQL Fiddle的结果,但我想要的是,名称和性别不会一直重复。
我附上截图:
我想要的是根据屏幕截图,姓名: John Doe和性别:男性,应该在最重要的位置,而不是继续重复,而下表显示所有访问细节。我试图修改代码,但它似乎没有真正解决。
请告诉我,因为我真的不知道如何实现我想要的目标。
非常感谢你。
答案 0 :(得分:1)
由于您在SQL查询中执行了LEFT JOIN
,因此您事先知道fname
返回的所有lname
,gender
和$q->fetch()
值将会是相同的 customer.slug
,对吧?所以你可以依靠它。
我的建议是使用fetchAll()函数来获取customer.slug
的所有记录数组,然后在视图中呈现它。例如(避免对此进行测试)您可以在$q->setFetchMode(PDO::FETCH_ASSOC);
...
$cs = $q->fetchAll(); // customer services join
然后,在<html>
视图中,您可以执行以下操作:
<h1>Customer Record</h1>
Name: <?php echo htmlspecialchars($cs[0]['fname'].' '.$cs[0]['lname']); ?> <br />
Gender: <?php echo htmlspecialchars($cs[0]['gender']); ?> <br />
<table>
<thead>
<tr>
<th>Treatment</th>
<th>Date</th>
</tr>
</thead>
<tbody>
<?php foreach($cs as $r): ?>
<tr>
<td><?php echo htmlspecialchars($r['treatment']); ?></td>
<td><?php echo htmlspecialchars($r['date']); ?></td>
</tr>
<?php endforeach; ?>
</tbody>
当然,检查查询是否返回任何记录并显示&#34; not found&#34;也可能是个好主意。消息,如果没有。毕竟,$cs[0]
可能为空,给你一个PHP错误。