php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 08.09.2006, 12:33  
Benutzer
 
Registriert seit: 10.06.2006
Beiträge: 31
tsvst
Standard MySQL-Abfrage in Kalender

Hi!

Ich habe auf meiner Seite einen Kalender, der das nächste halbe Jahr anzeigt. Jeder Tag steht dort einzeln. (In diesem Stil: http://www.thkoehler.de/midnightblue/m_kal.htm)

In meiner MySQL Datenbank habe ich nun eine umfangreiche Liste mit bestimmten Veranstaltungen und den Terminen. Immer wenn auf einem der Tage im Kalender ein Termin aus der Datenbank fällt, soll dieser fett adrgestellt werden.

Das ist auch alles kein Problem und durchführbar.

Was mir allerdings Kopfschmerzen bereitet, ist die Art und Weise, wie ich das mit den Abfragen gestalten soll. Denn ein halbes Jahr (über 180Tage) würde dann ja 180 MySQL-Abfragen auf einer Seite bedeuten!?

Und das ist doch sicher wahnsinnig ressourcenlastig ... Oder mache ich einen Denkfehler und man kann das auch anders hinkriegen?

In der MySQL Tabelle 'veranstaltungen' gibt es das Fehld 'datum', in dem die Termine im Format 0000-00-00 gespeichert sind und das Feld 'beschreibung', das den Namen der Veranstaltung enthält.
tsvst ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 08.09.2006, 14:11  
Erfahrener Benutzer
 
Registriert seit: 10.09.2004
Beiträge: 339
mkl0815
Standard

warum brauchst du denn 180 abfragen?

du kannst alle termine aus der db abfragen die größergleich dem heutigen tag und kleiner dem (heute + 180)sten tag sind. das ganze sortiert nach dem datum.
um die ergebnistabelle einzudampfen kannst du auch ein "SELECT ... datum, COUNT(datum) as anzahl FROM ... GROUP BY datum" einbauen. dann hast du ein ergebnis mit max. 180 einträgen und der zahl der Termine pro Datum. Das ganze in ein Array geschoben und beim ausgeben der Kalenders mit ausgewertet.

hth,
mario.
mkl0815 ist offline   Mit Zitat antworten
Alt 08.09.2006, 14:46  
Benutzer
 
Registriert seit: 10.06.2006
Beiträge: 31
tsvst
Standard

Achso..

$query = "SELECT datum FROM veranstaltungen WHERE datum > '$datumheute' GROUP BY datum";
$res = mysql_query($query, $link);
if (!$res) { echo "can't connect to database.
\n";};
$num = mysql_numrows($res);
$row = mysql_fetch_array($res);


Wie genau bekomme ich das nun in ein Array?
tsvst ist offline   Mit Zitat antworten
Alt 08.09.2006, 15:32  
Erfahrener Benutzer
 
Registriert seit: 10.09.2004
Beiträge: 339
mkl0815
Standard

also mit diesem aufruf bekommst du alle ab dem heutigen datum, also auch die nach dem 180sten tag.

PHP-Code:
$query "SELECT datum, count(datum) as anzahl FROM veranstaltungen WHERE datum > '$datumheute' AND datum < '$datumheute+180' GROUP BY datum ORDER BY datum"
dann in einem while die einzelnen zeilen mysql_fetch_row() abklappern und mit dem datum als key in ein ein ergebnisrarray schreiben

PHP-Code:
while($row mysql_fetch_row($res))
{
   
$erg[$row[0]]=$row[1];
}; 
dann sollte in $erg sowas stehen wie:
PHP-Code:
$erg['2006-09-10'] = 3
$erg
['2006-09-16'] = 1
$erg
['2006-09-30'] = 2
$erg
['2006-10-12'] = 1
... 
je nach ergebnis.

p.s. der php-code ist aus dem ärmel geschüttelt und erhebt keinen anspruch auf syntaktische korrektheit. bitte ggf. selber anpassen.

mario.
mkl0815 ist offline   Mit Zitat antworten
Alt 12.09.2006, 15:31  
Benutzer
 
Registriert seit: 10.06.2006
Beiträge: 31
tsvst
Standard

Toll!

Das klappt wunderbar.

Allerdings versuche ich nun, dem erg-Array noch per Hand Daten einzufügen.

Ich habe es mit z.B.

array_push($erg,"2007-01-23","2007-01-24");

probiert, aber es funktioniert nicht. $erg['2007-01-23'] ist weiterhin "0"..

Was mache ich falsch?
tsvst ist offline   Mit Zitat antworten
Alt 13.09.2006, 08:22  
Erfahrener Benutzer
 
Registriert seit: 10.09.2004
Beiträge: 339
mkl0815
Standard

hmm warum nicht einfach mit einem

PHP-Code:
$erg['2007-01-23']=1;
$erg['2007-01-24']=1
das ist eine einfache zuweisung, was anderes macht die schleife mit den datenbankergebnissen auch nicht.

mario.
mkl0815 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
Frage: richtige SQL Abfrage von einer MySQL Spalte die SET werte besitzt Seb PHP Tipps 2008 2 29.05.2008 11:36
MySQL Abfrage von Ver. 5 für Ver 3. des MySQL Servers FireFIghter Datenbanken 3 02.02.2007 17:18
Datum bezogene mysql abfrage ApfeL Datenbanken 5 22.10.2006 16:03
MySQL Abfrage macht Seite langsam Datenbanken 11 19.10.2006 19:38
MySQL - Abfrage: Unterschiedliche Ergebnisse aus PHP/manuell horstenpeter Datenbanken 3 16.07.2006 13:22
mysql abfrage in Schleife havok PHP Tipps 2006 6 09.05.2006 08:39
Abfrage bei mySQL 4 ApfeL Datenbanken 5 24.03.2006 18:53
MySQL Server startet nicht mehr richtig... Datenbanken 16 03.03.2006 19:40
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
Suche Tipps für Persormance-Steigerung (Geld für Nützliches) Beitragsarchiv 18 16.08.2005 10:57
MySQL Abfrage Problem. web2 PHP Tipps 2005-2 7 25.07.2005 11:07
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
MySQL mehrfach abfrage PHP Tipps 2004-2 3 22.11.2004 14:23
komplizierte mySQL Abfrage Datenbanken 6 25.06.2004 15:34
[Erledigt] mysql Abfrage Datenbanken 5 18.06.2004 14:16

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
mysql kalender, php kalender mysql, kalender mysql, kalender php mysql, php kalender mit mysql, php mysql kalender, php calendar with mysql request, calendar mysql, mysql tabelle kalender, php kalender datenbank, kalender mysql php, php mysql calendar, kalender abfrage, php kalender mysql datenbank, http://www.php.de/datenbanken/42008-mysql-abfrage-kalender.html, termine php mysql, terminkalender in mysql anlegen, php gruppenwechsel mysql für kalender, mysql php kalender, kalenderfunktion in mysql

Alle Zeitangaben in WEZ +2. Es ist jetzt 04:55 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.