CronJob-Service
bei SELFPHP mit ...
|
+ minütlichen Aufrufen
+ eigenem Crontab Eintrag
+ unbegrenzten CronJobs
+ Statistiken
+ Beispielaufrufen
+ Control-Bereich
Führen Sie mit den CronJobs von
SELFPHP zeitgesteuert Programme
auf Ihrem Server
aus. Weitere Infos
|
:: Anbieterverzeichnis ::
Globale Branchen
Informieren Sie sich über ausgewählte Unternehmen im Anbieterverzeichnis von SELFPHP
:: Newsletter ::
Abonnieren Sie hier den kostenlosen
SELFPHP Newsletter!
|
PHP für Fortgeschrittene und Experten Fortgeschrittene und Experten können hier über ihre Probleme und Bedenken talken |
06.03.2003, 16:04:46
|
Anfänger
|
|
Registriert seit: Mar 2003
Beiträge: 81
|
|
Abfrage von logdaten aus Datenbank
Aus einer Datenbank (beeinhaltet Logdaten) werden Daten abgefragt (was sonst ;) und mit PHP auf einer Webseite angezeigt.
Die abgefragte Tabelle beinhaltet Spalte wie Datum, IP, Event, Msg, ...
Das Datum ist dabei das wichtigste Filterkriterium. Ich möchte mir z.B. alle Logdaten von heute Anzeigen lassen.
"Select * from tabelle where datum > '2003-03-06 00:00' order by Datum desc"
Auf der ersten Seite sollen die letzten 50 erzeugten Logeinträge angezeigt werden. Ok, das bekomme ich noch hin, und zwar so:
while(db_fetch_row($res) and $counter < 50)
{
$Datum=mysql_result("Datum", $res);
$IP=mysql_result("IP", $res);
$Msg=mysql_result("Msg", $res);
echo "<tr bgcolor="#ffffcc"><td>$Datum</td>";
echo "<td>$IP</td>";
echo "<td>$Msg</td>";
$counter++;
}
Aber wie bekomme ich jetzt eine Navigationsleiste, in der man bequem auf z.B. Seite 33 springen kann, und dann die entsprechenden Daten angezeigt bekommt?
Welche Methoden sind effizient, da es sich hier ja um eine recht große Datenbank handelt?
|
06.03.2003, 16:40:53
|
|
|
06.03.2003, 17:03:15
|
Member
|
|
Registriert seit: Aug 2002
Beiträge: 775
|
|
für deine 50 einträge solltest du wahrscheinlich einfach mal limit verwenden.
"Select * from tabelle where datum > '2003-03-06 00:00' order by Datum desc limit 50"
da brauchst du keine komsichen schleifen zu bauen ;)
und dann bitte ne ordentlich schleife und nicht so ein scheiss.
Code:
while($row = mysql_fetch_array($res)){
echo "<tr bgcolor="#ffffcc"><td>".$row['datum']."</td><td>".$row['ip']."</td><td>".$row['msg']."</td></tr>";
}
ist schon etwas kürzer oder?
Geändert von MiH (06.03.2003 um 17:07:08 Uhr)
|
06.03.2003, 17:14:08
|
Anfänger
|
|
Registriert seit: Mar 2003
Beiträge: 81
|
|
Danke Ben20, dass werde ich mir mal noch genauer anschauen.
@ MiH
Dann werden aber auch nur wirklich 50 Datensätze abgefragt, oder? Wie soll ich dann die Links zu den restlichen Seiten (mit jeweils weiteren 50 Ergebnissen) realisieren?
|
06.03.2003, 17:18:03
|
|
Zitat:
Dann werden aber auch nur wirklich 50 Datensätze abgefragt, oder? Wie soll ich dann die Links zu den restlichen Seiten (mit jeweils weiteren 50 Ergebnissen) realisieren?
|
Das wird auch im dem Link erschlagen! Nur Kurz: Das Script gibt abhänig davon auf welcher Seite der User sich befindet einen dynamischen Wert für Limit raus
$limt = "LIMIT " . $seite * 50 . ", 50";
(den baut man dann in den SQL Query ein)
Die Links zu den Seite werden erstellt, indem Du zählst wieviele Einträge es gibt und die durch 50 teilst ( = Anzahl der Seiten)
Dann gibt man mit Hilfe einer Schleife für jede Seite einen Link in der Form aus:
<a href="bla.php4?seite=x">Zur Seite x</a>
|
10.03.2003, 11:58:18
|
Anfänger
|
|
Registriert seit: Mar 2003
Beiträge: 81
|
|
Es funktioniert jetzt. :-)
Allerdings habe ich noch ein Problem, mit MySql funktioniert es zwar, aber nicht wenn der Zugriff per ODBC erfolgt.
Funktioniert: mysql_query("Select * from tabelle where datum > '2003-03-06 00:00' order by Datum desc limit 0,15", $db);
Funktioniert nicht: odbc_exec ($db, "Select * from tabelle where datum > '2003-03-06 00:00' order by Datum desc limit 0,15");
odbc kennt scheinbar kein limit. Als alternative habe ich bisher nur den befehl "Top" gefunden. Aber wie soll man damit "limit" abbilden können?
Ideen, Lösungsvorschläge?
|
25.03.2003, 12:48:49
|
Anfänger
|
|
Registriert seit: Mar 2003
Beiträge: 81
|
|
für das ODBC Problem hab ich leider nichts gefunden. Hat keiner einen Rat?
|
25.03.2003, 15:07:46
|
|
Du könntest das Limit weglassen und eben nur dann ausgaben machen, wenn ein entsprechend eingerichteter Counter im richtigen Bereich ist!
$anfang = 0;
$ende = 15;
while($row = mysql_fetch_row($result)) {
if($i >= $anfang && $i <= $ende) {
echo "vfjkl";
}
}
Nicht die beste Lösung, aber vielleicht hilfts!
|
26.03.2003, 09:21:43
|
Anfänger
|
|
Registriert seit: Mar 2003
Beiträge: 81
|
|
ja, danke für dein Lösungsvorschlag. Was besseres hab ich auch nicht gefunden. Aus Performance sicht, zwar nicht das ideale, aber wenns nicht anders geht.
Für die erste Seite, hab ich noch "Select TOP 15 ..."
Das ist wesentlich schneller. Für die nächsten Seiten werde ich dann aber wohl deinen Ratschlag befolgen (müssen).
|
Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
|
|
Forumregeln
|
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.
HTML-Code ist aus.
|
|
|
Alle Zeitangaben in WEZ +2. Es ist jetzt 08:39:09 Uhr.
|