我对我做错了什么感到困惑。我已经在许多资源中看到了这一点,包括我正在学习PHP的书,看起来它应该是正确的......但它不起作用。内部连接ot返回第二个和第三个表的结果
<?php
try
{
$sql = 'SELECT parks.id, parks.state, parks.name, parks.description, parks.site, parks.sname, parks.street, parks.city, parks.zip, parks.phone FROM parks
INNER JOIN comments ON parks.parkid = comments.parkid
INNER JOIN photos ON parks.parkid = photos.parkid
INNER JOIN events ON parks.parkid = events.parkid';
$result = $pdo->query($sql);
}
catch (PDOException $e)
{
$error = 'Error fetching data: ' . $e->getMessage();
include 'output.html.php';
exit();
}
foreach ($result as $row)
{
$datas[] = array ('id' =>$row['id'],
'parkid' =>$row['parkid'],
'state' =>$row['state'],
'name' =>$row['name'],
'description' =>$row['description'],
'site' =>$row['site'],
'sname' =>$row['sname'],
'street' =>$row['street'],
'city' =>$row['city'],
'phone' =>$row['phone'],
'zip' =>$row['zip'],
'commentname' =>$row['commentname'],
'comment' =>$row['comment'],
'event' =>$row['event'],
'date' =>$row['date'],
'description2' =>$row['description2']);
}
include 'writing.html.php';
这将返回第一个表(公园)中的所有数据就好了。项目评论名称,评论,事件,日期和描述2来自连接表(事件和评论)
如果我回应'$ row ['state']'我得到一个正确的答案。但是,如果我回应其他表中的任何项目(例如$ row ['comment']),我不会得到任何结果。
我错过了什么?
你不上市返回数据,而不是返回列来自任何连接表的列返回 –
马克,我不明白你的答案。我应该在哪里列出它们,而不是在数组中?他们在阵列中。 – user1483042
该数组是从$ row中由SQL返回的$ result生成的...但如果您的$ sql没有列出列,那么它们将不在$ row中...查看下面的列表示例列,而不是一个完整的解决方案 –