我从 MySQL 表中提取了一条新闻流,其中显示了标题、故事和日期等内容。这些新闻故事是从 PHP foreach 循环生成的,并且运行良好。
我还有两个 MySQL 表,一个用于图像,一个用于视频。这些表有一个名为 news_id 的列,它与新闻表的唯一字段链接。这个想法是每个新闻故事都会自动显示任何附加的视频或图像。
但是,此代码无法正常工作 - 例如,如果一个故事有 3 个匹配的图像和一个视频,它实际上会输出该视频 3 次,每张图片旁边都有一个。同样,如果有 5 个视频和一张图片,它将显示该图片 5 次。
当它只是在新闻旁边拉图像时,代码工作正常,但由于我也添加了视频表,问题就开始了。我想我需要重写查询和 foreach 循环,但不知道如何。我的猜测是我在主 foreach 中需要两个 foreach 循环——一个用于图像,一个用于视频。
我希望它如何工作是:
为新闻表提取的标题、日期和故事
从图像表中提取的任何 photo_url
从视频表中提取的任何 video_url
然后是下一个标题,依此类推。谁能帮我构建这个?
作为参考,这是当前使用的查询:
$sql = 'SELECT headline, story, DATE_FORMAT(date, "%d-%M-%Y") AS Displaydate, name, logo, tpf_parks.park_id, url, alt, description, credit, location
FROM tpf_news
INNER JOIN tpf_parks ON tpf_news.park_id = tpf_parks.park_id
LEFT JOIN tpf_images ON tpf_news.news_id = tpf_images.news_id
LEFT JOIN tpf_videos ON tpf_news.news_id = tpf_videos.news_id
ORDER BY date DESC' ;
$result = $pdo->query($sql);
和当前使用的 php:
$sLastStory = '';
foreach ($result AS $row)
{
$sStory = $row['headline'] . $row['story'];
if (strcasecmp($sStory, $sLastStory) != 0)
{
if (!empty($sLastStory))
{
print('<hr>' . PHP_EOL);
}
$sLastStory = $sStory;
printf('<h2>%s</h2>' . PHP_EOL, $row['headline']);
printf('<h3><a href="parknews.php?park_id=%s">
%s</a> - %s</h3>' . PHP_EOL, $row['park_id'], $row['name'], $row['Displaydate']);
printf('<p>%s</p>' . PHP_EOL, $row['story']);
}
if(!empty($row['url'])){
printf('
<a href="/images/%s%s.jpg" rel="lightbox[%s]" title="%s - Credit - %s" >
<img src="/images/%s%s-thumb.jpg" style="max-height: 250px; max-width: 250px" alt="%s"/></a>' . PHP_EOL, $row['url'], $row['alt'], $row['headline'], $row['description'],$row['credit'], $row['url'], $row['alt'], $row['alt'] );
}
if(!empty($row['location'])){
printf('<iframe width="640" height="360" src="%s" allowfullscreen></iframe>' . PHP_EOL, $row['location'] );
}
}
如何使此代码正常工作以根据需要显示数据? 但正如我所说,我认为这一切都需要彻底重写。