problem mit foreach ausgabe

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • problem mit foreach ausgabe

    hallo,

    habe eine abfrage aus ner db in ein array gepackt und will es per foreach nacheinander ausgeben. leider gibt mir der quelltext jeden wert zweimal aus.

    die tabelle hat 3 spalten und 3 einträge wobei nur der inhalt der mittleren (2.) spalte gefragt/erfragt wird.

    aber für jeden dieser drei einträge erhalte ich zweimal die gleiche ausgabe des inhalts der jeweiligen zelle.

    kann mir jemand sagen warum oder wo ich da auf dem schlauch stehe?

    thx


    PHP-Code:
    <?php
    echo mysql_error();
    error_reporting(E_ALL);
    session_start();

    require(
    "connect.inc.php");

    $query_count mysql_query("SELECT bez_sg FROM zaehler");
    //Anzahl der Datensätze aus "zaehler" auslesen    
    $anzahl    =    mysql_num_rows$query_count );
    //Anzahl der Datensätze ausgeben
    echo "Anzahl der Datensätze: " $anzahl."<br>";

    for (
    $i=1$i <= $anzahl$i++)
        {
        
            
    $datensatz    =    mysql_fetch_array$query_count );
        
            foreach( 
    $datensatz as $dsg)
                {
                    
                    echo 
    "Inhalt: ".$dsg."</p>";
                    
                }
        }

    ?>

  • #2
    mysql_fetch_array() ist eine erweiterte Version von mysql_fetch_row(). Die Daten werden sowohl unter numerischen Indizes des Ergebnis-Arrays abgelegt, als auch unter assoziativen Indizes. Als Schlüssel für die assoziativen Indizes werden die Feldnamen benutzt.
    ps: dein for + foreach kannst du auch in einer while-schleife abhandeln.

    Kommentar


    • #3
      ja, in etwa so:

      PHP-Code:
      $query_count mysql_query("SELECT bez_sg FROM zaehler");
      //Anzahl der Datensätze aus "zaehler" auslesen    
      $anzahl    =    mysql_num_rows$query_count );
      //Anzahl der Datensätze ausgeben
      echo "Anzahl der Datensätze: " $anzahl."<br>";

      for (
      $i=1$i <= $anzahl$i++)
          {
              while (
      $datensatz    =    mysql_fetch_array$query_count ))
              echo 
      $datensatz['bez_sg']; 
              
      /* $datensatz    =    mysql_fetch_assoc( $query_count );
          
              foreach( $datensatz as $dsg)
                  {
                      
                      echo "Inhalt: ".$dsg."<p>";
                      
                  } */
          
      }

      ?> 
      dann bekomm ich aber nur den letzten der drei datensätze ausgegeben

      Kommentar


      • #4
        du läufst mit foreach jede spalte der zeile ab

        Kommentar


        • #5
          ja, so war es gedacht @ BugBite

          Kommentar


          • #6
            ok, das is ne komische art datensätze auszulesen

            PHP-Code:
            $result mysql_query(...)

            while(
            $row=mysql_fetch_assoc($result)){
            echo 
            $row['column'];

            damit sparst du dir ne schleife und es kommt nichts doppelt

            Kommentar


            • #7
              Original geschrieben von BugBite
              damit sparst du dir ne schleife und es kommt nichts doppelt
              das "doppelte" kam hauptsächlich durch sein mysql_fetch_array()

              Kommentar


              • #8
                stimmt, 3d. mit fetsh_assoc ging es besser aber die while-schleife funktioniert super, vor allem, da jetzt eine in der foreach-schleife befindliche do-while-schleife funzt und die um die foreach liegende for-schleife nicht mehr benötigt wird, da diese eh nicht funktioniert hat und nur einmal ablief, ist mir also damit hervorprächtig geholfen.

                danke dafür an alle

                @BugBite: ich hab das so meinem v2b php/mysql entnommen und im php-buch steht, dass man arrays nur auf diese weise nacheinander abarbeiten kann. das war dann wohl leider falsch.

                Kommentar

                Lädt...
                X