繁体   English   中英

基于元素在PHP中组合SQL查询数组

[英]Combining SQL query Array in PHP based on element

我在网站上设置了“收藏夹”功能,使某人可以选择不同的物品,并将其另存为收藏夹。 所有项目均保存在具有收藏夹ID号的收藏夹表中。 具有相同ID号的任何东西都一起去。 这将保存在已登录的客户下。

我正在尝试将此数组导入PHP页面并以灯箱类型外观以图形方式显示项目,但将它们组合在一起以正确显示它们时遇到了很多麻烦。

数组和php代码如下。 该数组是从SQL查询生成的。 数组[0]和[1]的各项需要组合在一起,以便我可以一起显示彼此的图像(图像实际上彼此叠放在一起,使其看起来像一个包装。

这是页面的链接,因此您有个好主意: https : //www.viva-cards.com/products/package-designer您将无法看到喜欢的功能,除非您登录

我基本上需要将相同的fav_seq id组合在一起,但仍然能够区分itm_id,offer_id,inv_type_id,inv_thumbnail_url和offer_description,因为它们具有不同的图像,并且它们具有相似的含义。 我一直在撞墙。 有没有办法在php页面上执行此操作,还是必须在SQL查询阶段执行此操作? 我究竟做错了什么?

以下是数组的代码:

[0] => Array
    (
        [entity_id] => 6
        [itm_id] => 81
        [fav_seq] => 1
        [offer_id] => 1
        [inv_css_tag] => 
        [inv_type_id] => TYPE1
        [inv_thumbnail_url] => image1-thumb.png
        [offer_description] => Offer1
    )

[1] => Array
    (
        [entity_id] => 6
        [itm_id] => 198
        [fav_seq] => 1
        [offer_id] => 1
        [inv_css_tag] => csstag
        [inv_type_id] => TYPE2
        [inv_thumbnail_url] => image2-thumb.jpg
        [offer_description] => Offer2
    )

[2] => Array
    (
        [entity_id] => 6
        [itm_id] => 810
        [fav_seq] => 2
        [offer_id] => 4
        [inv_css_tag] => 
        [inv_type_id] => TYPE1
        [inv_thumbnail_url] => image3-thumb.png
        [offer_description] => Offer4
    )

[3] => Array
    (
        [entity_id] => 6
        [itm_id] => 98
        [fav_seq] => 2
        [offer_id] => 4
        [inv_css_tag] => csstag
        [inv_type_id] => TYPE2
        [inv_thumbnail_url] => image4-thumb.jpg
        [offer_description] => Offer4
    )

这是我在php页面上用来生成显示的代码:

<div>
    <h2>Favorites Saved</h2>

    <?php 
    foreach($this->favorite_seq as $favorites){
        if(empty($favorites['fav_seq'])){ 
     // Nothing
    ?>
<?php }else {?>                 
        <div id="favoritesThumbnailWrapper"> <!-- For TYPE1 -->
     <div id="favoritesReferralThumb" class="cardPositionMiddle1">
         <img src="<?= $this->inventory_url . $favorites['inv_thumbnail_url'];?>">
     </div>

     <div id="favoritesPresentationThumb"> <!-- For TYPE2 -->
         <img src="<?= $this->inventory_url . $favorites['inv_thumbnail_url'];?>">
     </div>

     <div id="favoritesOffer"> <!-- For OFFER DESCRIPTION -->
         <span><?= $favorites['offer_description'];?></span>
     </div>

</div>
<?php
    }
}
?>

这可能会有所帮助:

$favArray = array();
foreach($this->favorite_seq as $favorites){
    if(!empty($favorites['fav_seq'])){
        $favArray[$favorites['fav_seq']][] = $favorites;
    }
}
print_r($favArray);

迭代$favArray以显示记录。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM