php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 21.03.2007, 17:13  
Neuer Benutzer
 
Registriert seit: 30.12.2004
Beiträge: 16
elconde
Standard SQL Abfrage läuft nach Providerwechseln nicht mehr optimal

Hallo,

ich habe vor kurzer Zeit meinen Provider gewechselt und seitdem läuft das Portal nicht mehr schnell, weil eine Abfrage für die aktuellsten 5 Threads aus dem Forum das ganze ausbremst. Nun würde ich gerne wissen, wo der Fehler liegen kann, wenn es beim alten Provider ganz normal geklappt hat. Ohne die Abfrage der neusten Threads läuft das Portal (noch in der bauphase) ganz normal schnell.

Hier ist der Code für die Abfrage. Vielleicht hilft es ja. Das Forum ist auf dem neusten Stand.

PHP-Code:
<?PHP
     
//forum.php
    
     
$limit=5// Maximal angezeigte Anzahl der Threads
     
$count=1// hier wird losgezählt
     
$topic_id=1// der erste Thread fällt mal zum raus, um die Variable zu haben
     
$array=array();
     
$array_var="topic_id not like 1";
     
     
// DB Connect    
     
[gelöscht]
     
     
// Aktuelle Posts holen
     #$get_posts=mysql_query("SELECT post_id, topic_id, forum_id, poster_id, FROM_UNIXTIME( (post_time), '%d.%m.%Y - %H:%i' ) AS datum FROM `phpbb_posts` ORDER BY post_id DESC LIMIT 1 " );
     
     // Spezifikation der Einträge
     
     
while($count<=$limit){
         if(
$topic){
         
$topic_id=$topic;
         
$array[$count]=$topic;
         
$array_var=$array_var." and topic_id not like ".$array[$count];
         }        
    
// Aktuelle Posts holen
    
$get_posts=mysql_query("SELECT post_id, topic_id, forum_id, poster_id, FROM_UNIXTIME( (post_time), '%d.%m.%Y - %H:%i' ) AS datum FROM `phpbb_posts` where $array_var ORDER BY post_id DESC LIMIT 1 " );
     while(
$row mysql_fetch_object($get_posts)){
         
          
$poster $row->poster_id;
          
$forum $row->forum_id;
          
$topic $row->topic_id;
          
$linkid $row->post_id;
          
$datum $row->datum;
          
          
// Abfrage des Poster-Name
          
$get_poster=mysql_query("SELECT username FROM `phpbb_users` WHERE user_id = $poster ");
          
$row1 mysql_fetch_object($get_poster);
          
$poster_name=$row1->username;
          
          
// Abfrage des Foren-Name
          
$get_forum=mysql_query("SELECT forum_name, cat_id FROM `phpbb_forums` WHERE forum_id = $forum");
          
$row2 mysql_fetch_object($get_forum);
          
$forum_name=$row2->forum_name;
          
$cat_id=$row2->cat_id;
          
           
// Abfrage der Kategorie (Hauptstudium/Grundstudium...)
          
$get_cat=mysql_query("SELECT cat_title FROM `phpbb_categories` WHERE cat_id = $cat_id");
          
$row5 mysql_fetch_object($get_cat);
          
$cat_name=$row5->cat_title;
          
          
// Abfrage des Thread-Name
          
$get_thread=mysql_query("SELECT topic_title FROM `phpbb_topics` WHERE topic_id = $topic");
          
$row3 mysql_fetch_object($get_thread);
          
$Titelvar=$row3->topic_title;
          
          
// Abfrage der Antworten für den jeweiligen Thread
          
$get_answer=mysql_query("SELECT topic_replies FROM `phpbb_topics` WHERE topic_id = $topic");
          
$row4 mysql_fetch_object($get_answer);
          
$Answervar=$row4->topic_replies;
          
          
// Abfrage, ob Beitrag von "Heute" ist...
          
$zwischenspeicher1 $row->datum;
          
$zwischenspeicher2 substr($zwischenspeicher10, -8);
          
$heute date("d.m.Y");
          if (
$heute == $zwischenspeicher2){
              
$zwischenspeicher3 substr($zwischenspeicher110);
              
$datum "[i][b]heute[/b][/i]".$zwischenspeicher3;
          }
    
// Abfrage der Anzahl der Einträge des aktuellen Datums
    
    
$get_number=mysql_query("SELECT COUNT(post_id) AS anzahl, CURDATE() AS today FROM phpbb_posts WHERE FROM_UNIXTIME(post_time, '%Y-%m-%d') = CURDATE() GROUP BY FROM_UNIXTIME(post_time, '%Y-%m-%d') " );
    
$number "Null";
    while(
$zeile mysql_fetch_object($get_number)){
    
$number $zeile->anzahl;    
    } 
// aktuell
    
    // Abfrage der Anzahl der Einträge des Vortages
    
    
$tstamp  mktime(000date("m"), date("d")-1date("Y"));
    
$gestern date("Y-m-d"$tstamp);  // ISO-8601 Format
    
    
$get_number_y=mysql_query("SELECT COUNT( post_id )  AS anzahl, CURDATE(  )  AS today FROM phpbb_posts WHERE FROM_UNIXTIME( post_time,  '%Y-%m-%d'  )  = '$gestern'" );
    
$number_y "Null";
    while(
$zeile1 mysql_fetch_object($get_number_y)){
    
$number_y $zeile1->anzahl;    
    } 
// Vortag
    
         
if (strlen($Titelvar) > 45)
         
$Titelvar substr($Titelvar045)."...";
          
          
// Ausgabe in html
          
echo "<div id=\"start_last_entries\"><a href=\"http://www.campuszentrale.de/uni-kiel/forum/viewtopic.php?p=".$linkid."#".$linkid."\" class=\"special_link\">".$Titelvar."</a>
 
          Forum: <a href=\"http://www.campuszentrale.de/uni-kiel/forum/viewforum.php?f="
.$forum."\">[".$forum_name."] </a>
Kategorie: [b]"
.$cat_name."[/b]
 
           am: "
.$datum." von: ".$poster_name." || AW: ".$Answervar."<div id=\"linie\"></div>
          </div>"
;
    }    

    
$count++;
    }
// while(count)      
    
echo "<div id=\"anzahl_beitraege\">";
    echo 
"Beitr&auml;ge [i][b]heute:[/b][/i]&nbsp&nbsp&nbsp ".$number."";
    echo 
"
Beitr&auml;ge [i][b]gestern:[/b][/i] "
.$number_y."";
    echo 
"</div>";
    
     
//für das Auswahlformular
     
$morgen=mktime(000date(m), date(d)+1date(y));
     
$heute=mktime(000date(m), date(d), date(y));
     
$gestern=mktime(000date(m), date(d)-1date(y));
     
$vorgestern=mktime(000date(m), date(d)-2date(y));
     
$pruefvar "nein";
?>
    <div id="alle_beitraege">    
            <form action="index.php?section=forum_dropdown" method="post">
                <select class="dropdown_entry" name="url" onchange="this.form.submit()" >
                <option class="dropdown_entry" value="<? echo $heute ?>" selected>Alle Eintr&auml;ge anzeigen von:</option>
                <option class="dropdown_entry" value="<? echo $heute ?>">Heute</option>
                <option class="dropdown_entry" value="<? echo $gestern ?>">Gestern</option>
                <option class="dropdown_entry" value="<? echo $vorgestern ?>">Vorgestern</option>
                <option class="dropdown_entry" value="<? echo "noanswer"?>">UNBEANTWORTETE</option>
                </select>
            </form>
        </div>
Bin für jeden Tip dankbar!

Gruß
Alex
elconde ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 21.03.2007, 20:10  
Erfahrener Benutzer
 
Registriert seit: 17.01.2006
Beiträge: 468
Slava
Standard

es kann natürlich an überförderten Mysql-server von neuem provider liegen.
aber allgemein ist deine abfrage richtig schrotmässig aufgebaut.
hast du schon was über Join gehört?
ausserdem schau dir wie du $Titelvar und $Answervar abfragst!
das gehört doch in eine query!!
ich würde mals behaupten, dass dein codestück mit 2 queris zu erlädigen ist.
durch so eine abfrage, kannst du dir direkt 6 queris sparen und viel zeit bei den überförderten server.
Code:
SELECT 
phpbb_posts.post_id, 
phpbb_posts.topic_id, 
phpbb_posts.forum_id, 
phpbb_posts.poster_id,
phpbb_users.username,
phpbb_forums.forum_name, 
phpbb_forums.cat_id,
phpbb_categories.cat_title, 
phpbb_topics.topic_title,
phpbb_topics.topic_replies    
FROM_UNIXTIME( (post_time), '%d.%m.%Y - %H:%i' ) AS datum
 
FROM `phpbb_posts` inner join phpbb_users 
on phpbb_users.user_id =phpbb_posts.poster_id
inner join phpbb_forums
on phpbb_forums.forum_id=phpbb_posts.forum_id
jnner join phpbb_categories
on phpbb_categories.cat_id=phpbb_forums.cat_id
inner join phpbb_topics
on phpbb_topics.topic_id = phpbb_posts.topic_id
where phpbb_posts.topic_id !=1 ORDER BY phpbb_posts.post_id DESC LIMIT 1
jetzt habe ich kein bock mehr deine code weiter zu optimieren
__________________
Slava
http://bituniverse.com
Slava ist offline   Mit Zitat antworten
Alt 21.03.2007, 22:04  
Neuer Benutzer
 
Registriert seit: 30.12.2004
Beiträge: 16
elconde
Standard

ok, danke für die kritik. das war glaube ich eine meiner ersten mysql abfragen vor 3 jahren. ich werde es mal (versuchen ) optimieren. ich frage mich nur, warum es auf dem anderen webspace so gut geklappt hat.
elconde ist offline   Mit Zitat antworten
Alt 21.03.2007, 23:42  
Erfahrener Benutzer
 
Registriert seit: 17.01.2006
Beiträge: 468
Slava
Standard

Zitat:
Zitat von elconde
ich frage mich nur, warum es auf dem anderen webspace so gut geklappt hat.
also noch einmal.
Zitat:
Zitat von Slava
es kann natürlich an überförderten Mysql-server von neuem provider liegen.
__________________
Slava
http://bituniverse.com
Slava ist offline   Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Abfrage von einer Abfrage Datenbanken 5 27.01.2011 23:31
mysql abfrage in Schleife havok PHP Tipps 2006 6 09.05.2006 08:39
abfrage begrenzen Cyrus Datenbanken 4 26.10.2005 11:29
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
Abfrage in array? BartTheDevil89 Datenbanken 5 10.05.2005 14:21
[Erledigt] IF() abfrage in variable packen PHP Tipps 2005 14 01.04.2005 17:23
Abfrage von Char-Feldern Datenbanken 9 04.02.2005 14:06
[Erledigt] SQL Abfrage funzt nicht Datenbanken 2 04.02.2005 11:09
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
2 Tabellen 1 Abfrage nilsfeld Datenbanken 6 11.08.2004 11:18
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00
komplizierte mySQL Abfrage Datenbanken 6 25.06.2004 15:34
[Erledigt] mysql Abfrage Datenbanken 5 18.06.2004 14:16
[Erledigt] Variable per GET übergeben und DB Abfrage nutzen PHP Tipps 2004 4 01.06.2004 15:17

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
sql 2005 abfrage was aktuell läuft, abfrage optimal, index altt von tabelle phpbb_topics, sql optimal in php?

Alle Zeitangaben in WEZ +2. Es ist jetzt 06:03 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.