vb.org Archive

vb.org Archive (https://vborg.vbsupport.ru/index.php)
-   vB3 Programming Discussions (https://vborg.vbsupport.ru/forumdisplay.php?f=15)
-   -   Help with news page hack I made (https://vborg.vbsupport.ru/showthread.php?t=191499)

DionDev 09-21-2008 03:53 PM

Help with news page hack I made
 
I am looking for some help with this. Now it works, but it doesn't seem to be as efficient as I would like it to be. I mean sometimes it takes a couple of seconds to display the page. The execution time is what I am worried about.

Could any PHP gurus give some input as to how I could improve this news page script I wrote? (it grabs news from a specified forum and spits it out onto a php page)

PHP Code:

<?php

chdir
('./forums');
require_once(
'./global.php');
require_once(
'./includes/class_bbcode.php'); 

$parser =& new vB_BbCodeParser($vbulletinfetch_tag_list());

$dbhost 'localhost';
$dbname '*****';
$dbuser '*****';
$dbpass '*****';

mysql_connect($dbhost$dbuser$dbpass);
mysql_select_db($dbname);
        
$sql 'SELECT post.pagetext, thread.*
        FROM post AS post, thread AS thread
        LEFT JOIN forum AS forum ON (forum.forumid = thread.forumid)
        WHERE FIND_IN_SET(4, forum.parentlist) AND post.postid = thread.firstpostid
        ORDER BY thread.dateline DESC
        LIMIT 5'
;

$sqlresult mysql_query($sql) or die(mysql_error());
$count mysql_num_rows($sqlresult);

while (
$row mysql_fetch_array($sqlresult))
{
  
$subject $row['title'];
  
$poster $row['postusername'];
  
$posterid $row['postuserid'];
  
$time date("D, M j, Y"$row['dateline']);
  
$replies $row['replycount'];
  
$id $row['threadid'];
  
$text $parser->do_parse($row['pagetext'], truetruetruetruetruefalse);
  
  if (
$replies == 1)
    
$replytext 'reply';
  else
    
$replytext 'replies';
  
  echo 
"<b>$subject</b>";
  
  echo 
'<br>';
  
  echo 
'<font style="font-size: 8pt;">';
  echo 
"Posted by <a href=\"forums/member.php?u=$posterid\">$poster</a> on $time (<a href=\"forums/showthread.php?t=$id\">$replies $replytext</a>)";
  echo 
'</font>';
  
  echo 
'<br><br>';
  
  echo 
$text;
}

echo 
'<br><br><div style="float: right;"><a href="forums/forumdisplay.php?f=4">News Archive Forum</a></div>';

?>


MoT3rror 09-23-2008 02:38 AM

One it is best to use vBulletin db functions so you only use one database connection.
https://vborg.vbsupport.ru/showthrea...database+class

But if you want to stay with the mysql default functions, it would probably be best to change your code to this.

PHP Code:

chdir('./forums');
require_once(
'./global.php');
require_once(
'./includes/class_bbcode.php'); 

$parser =& new vB_BbCodeParser($vbulletinfetch_tag_list());

$dbhost 'localhost';
$dbname '*****';
$dbuser '*****';
$dbpass '*****';

$dbconnection mysql_connect($dbhost$dbuser$dbpass);
mysql_select_db($dbname$dbconnection);
        
$sql 'SELECT post.pagetext, thread.*
        FROM post AS post, thread AS thread
        LEFT JOIN forum AS forum ON (forum.forumid = thread.forumid)
        WHERE FIND_IN_SET(4, forum.parentlist) AND post.postid = thread.firstpostid
        ORDER BY thread.dateline DESC
        LIMIT 5'
;

$sqlresult mysql_query($sql$dbconnection) or die(mysql_error());
$count mysql_num_rows($sqlresult);

while (
$row mysql_fetch_array($sqlresult))
{
  
$subject $row['title'];
  
$poster $row['postusername'];
  
$posterid $row['postuserid'];
  
$time date("D, M j, Y"$row['dateline']);
  
$replies $row['replycount'];
  
$id $row['threadid'];
  
$text $parser->do_parse($row['pagetext'], truetruetruetruetruefalse);
  
  if (
$replies == 1)
    
$replytext 'reply';
  else
    
$replytext 'replies';
  
  echo 
"<b>$subject</b>";
  
  echo 
'<br>';
  
  echo 
'<font style="font-size: 8pt;">';
  echo 
"Posted by <a href=\"forums/member.php?u=$posterid\">$poster</a> on $time (<a href=\"forums/showthread.php?t=$id\">$replies $replytext</a>)";
  echo 
'</font>';
  
  echo 
'<br><br>';
  
  echo 
$text;
}

mysql_close($dbconnection);

echo 
'<br><br><div style="float: right;"><a href="forums/forumdisplay.php?f=4">News Archive Forum</a></div>'



All times are GMT. The time now is 03:24 PM.

Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2025, vBulletin Solutions Inc.

X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01718 seconds
  • Memory Usage 1,753KB
  • Queries Executed 10 (?)
More Information
Template Usage:
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (2)bbcode_php_printable
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_navbar_search
  • (1)printthread
  • (2)printthreadbit
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • showthread
Included Files:
  • ./printthread.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/class_bbcode_alt.php
  • ./includes/class_bbcode.php
  • ./includes/functions_bigthree.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • printthread_start
  • bbcode_fetch_tags
  • bbcode_create
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • printthread_post
  • printthread_complete