gpt4 book ai didi

php - foreach 循环中的 foreach 循环

转载 作者:行者123 更新时间:2023-11-29 03:04:42 24 4
gpt4 key购买 nike

我从 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'] );
}

}

我怎样才能让这段代码正常工作以显示我想要的数据?但正如我所说,我认为这一切都需要完全重写。

最佳答案

你可以使用 GROUP_CONCAT .这将返回一个连接的字符串,然后您可以使用 explode()。这将使每个标题返回 1 行,因此您可以轻松地对图像和视频进行分组。

$sql = 'SELECT headline, story, DATE_FORMAT(date, "%d-%M-%Y") AS Displaydate, 
name, logo, tpf_parks.park_id,
GROUP_CONCAT(url) as url, GROUP_CONCAT(alt) as alt, GROUP_CONCAT(description) as description,
GROUP_CONCAT(credit) as credit, GROUP_CONCAT(DISTINCT location) as 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
GROUP BY tpf_images.news_id, tpf_videos.news_id
ORDER BY date DESC' ;
$result = $pdo->query($sql);

然后在您的循环中,对每个连接的列使用 explode() -

if(!empty($row['url'])){ 
$url=explode(',',$row['url']);
$alt=explode(',',$row['alt']);
$description=explode(',',$row['description']);
$credit=explode(',',$row['credit']);

for($i=0;$i<count($url);$i++){
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, $url[$i], $alt[$i], $row['headline'], $description[$i],$credit[$i], $url[$i], $alt[$i], $alt[$i] );
}
}

if(!empty($row['location'])){
$location=explode(',',$row['location']);
for($j=0;$j<count($location);$j++){
printf('<iframe width="640" height="360" src="%s" allowfullscreen></iframe>' . PHP_EOL, $location[$j] );
}
}

关于php - foreach 循环中的 foreach 循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17606324/

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