Thread: Foreach Loop
View Single Post
  #10  
Old 01-16-2008, 07:36 AM
Tefra's Avatar
Tefra Tefra is offline
 
Join Date: Mar 2005
Posts: 68
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I suggest you one really helpful change to calculate the total entries of each category during the add,delete,move of the download entries. This way you will save the count query.

PHP Code:
// Part One This could be cached in datastore to save even more queries//
// The cache should be re-written each time you manage the categories and after the add/delete/move of a download entry //
$sql $db->query_read("SELECT * FROM `" TABLE_PREFIX "xsdl_cats` WHERE 1");
while (
$row $db->fetch_array($sql))
{
    
$catcache[$row['cid']] =  $row;
    
$icatcache[$row['par_cat']][$row['cid']] = $row['cid'];
}

$vbulletin->input->clean_array_gpc('g''id'TYPE_INT);
$id = (empty($vbulletin->GPC['id'])) $vbulletin->GPC['id'];

// Part Two Build teh cat list //
foreach ($icatcache[$id] AS $cid)
{
    if (empty(
$icatcache[$id])) continue;
    
    
$cname             $catcache[$cid]['cat_name'];
    
$description     $catcache[$cid]['cat_description']; 
    
$file_loc         $catcache[$cid]['file_loc']; 
    
$screen_loc     $catcache[$cid]['screen_loc']; 
    
$count            xs_calc_total($cid);
    foreach(
$icatcache[$cid] AS $subcid// Grab one level of subcats //
    
{
    
        
$sub_cname             $catcache[$subcid]['cat_name'];
        
$sub_description     $catcache[$subcid]['cat_description']; 
        
$sub_file_loc         $catcache[$subcid]['file_loc']; 
        
$sub_screen_loc     $catcache[$subcid]['screen_loc'];
        eval(
'$downloads_subs_bit .= "' fetch_template('xs_downloads_subs_bit') . '";'); 
    }    
    eval(
'$downloads_bit .= "' fetch_template('xs_downloads_bit') . '";'); 
}

function 
xs_calc_total($id$total 0)
{
    global 
$icatcache$catcache;
    
    
$total += $catcache[$id]['total']; // Grab the total from the current category //
    
    
foreach($icatcache[$id] AS $cid// Recursive grab the total from all the subs //
    
{
        
$total += xs_calc_total($cid$total);
    }
    return 
$total;

Reply With Quote
 
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01170 seconds
  • Memory Usage 1,803KB
  • Queries Executed 11 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD_SHOWPOST
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)bbcode_php
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_box
  • (1)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (1)post_thanks_postbit_info
  • (1)postbit
  • (1)postbit_onlinestatus
  • (1)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • reputationlevel
  • showthread
Included Files:
  • ./showpost.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_postinfo_query
  • fetch_postinfo
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showpost_start
  • bbcode_fetch_tags
  • bbcode_create
  • postbit_factory
  • showpost_post
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • showpost_complete