Seitenfunktion orientiert an Daten(Datum)

Nepheus

Erfahrenes Mitglied
Hey Leute,

hab hier ein kleinen Codeschnipsel das folgendes tun soll:
(Hoffe das versteht jemand, is bisschen kompliziert)
Ich habe viele Einträge in einer Datenbank mit dazugehörigen Daten(Datum). Mal hat ein Datum 5 Einträge oder mal 12, ist halt immer verschieden, kommt halt drauf an wieviele Einträge es dazu gibt. Jetzt gehts um das Problem und zwar um die "Seitenfunktion". ich kann diese nicht für jede Seite auf 10 Einträge limitieren weil ich sonst 10 Einträge und nicht (so wie ich es will) 10 DATEN angezeigt bekomme. Der Code soll jetzt alle Einträge nach "sort" sortieren und bei jedem Datumswechsel $gesamt eins hochzählen. Also beim 10. Datumswechsel soll er aus der $_SESSION["seite1"] (die bis hierhin immer eins hochgezählt wurde) $_SESSION["seite2"] machen und diese weiterhochzählen bis zum Wert 20 usw... nun hab ich alles getestet, doch $_SESSION["seite1"] hat einen zu großen Wert. Sie ist etwa um 10 zu hoch gezählt und so hab ich jetzt 12 Daten auf der ersten Seite angezeigt anstatt den gewünschten 10. Ich finde echt nicht den Fehler im Code und wär froh wenns einer von euch tun würde!

Hier der Code:
PHP:
$eintraege="0";
$gesamt="0";
$sort="0";
$i="10";
$_SESSION["proseite".$i/10]="0";
$sql = "SELECT * FROM jura_kasse WHERE nutzen='1' ORDER BY sort";
$rs = mysql_query ($sql, $dbverbindung);
while($row = mysql_fetch_array($rs, MYSQL_ASSOC)){
  if($sort!=$row["sort"]){
    $gesamt++;
    $sort=$row["sort"];
    if($gesamt>$i){
      $i+="10";
    }
  }
  $_SESSION["seite".$i/10]++;
  $eintraege++;
}


Greetz
 
könntet ihr mir wenigstens sagen ob ihr kein bock habt zu antworten oder ob ihr die lösung nicht kennt ^.^ xD
 
Erstens mal die kompletten Daten in ein Array auslesen. Alle einzelnen Daten(Datumstage) als ein element in ein array schreiben.

zum Beispiel sieht das denn so aus

$daten_array ( [25.02.2007] => [0] lala
[1] lala2
.....
[26.02.2007 => [0] lolo
[1] lolo2

also nen mehrdimensionales array erstellen. SO kannst du dann 10 daten einfach runterzählen und eben ausgeben.

Ist mein Vorschlag.
 
Also was mit so auf den ersten Blick auffällt, wenn du mit Zahlen arbeitest, solltest du auch Zahlen nehmen.

PHP:
$n = 10;
$s = '10';

$n += 10; 
echo $n; // 20

$s += '10';
echo $s; // '1010'

hab ich nicht getestet, müsste aber so sein und möglicherweise liegt da auch der Fehler, oder?

Dirk
 
Zurück