2

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

}

如何使此代码正常工作以根据需要显示数据? 但正如我所说,我认为这一切都需要彻底重写。

4

1 回答 1

1

你可以使用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] );
   }
}
于 2013-07-12T05:44:35.740 回答