Hilfe zu JPGraph und Datenbank abfrage

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

  • Hilfe zu JPGraph und Datenbank abfrage

    Hallo allerseits,
    ich hoffe das ich hier im richtigen Bereich bin, wenn nicht bitte verschieben.
    Also folgendes: Ich möchte meine Gasverbrauch Auswerten,dazu habe ich den Gaszähler angezapft und nun werden in meiner mySQL(Gas) folgende Werte gepeichert:
    Code:
    id  ~ 1
    datumzeit ~ 19-12-12-13-08-05
    GZStand ~ 856225
    Ich versuche mich gerade mit JPGraph anzufreunden und möchte die Ausgabe als Balkendiagramm darstellen.
    Nun die FRAGE, wie kann ich die Datenbank abfragen, das mir nur der Verbrauch vom heutigen Tag angezeigt wird ?

    Mein ansatz sieht so aus, DB Zugang:
    Code:
    <?php
    define('DB_SERVER',"localhost");
    define('DB_NAME',"Gas");
    define('DB_USER',"stefan");
    define('DB_PASSWORD',"12345");
     
    $conn = mysql_connect(DB_SERVER, DB_USER, DB_PASSWORD);
    if(is_resource($conn))
    {
      mysql_select_db(DB_NAME, $conn);
      mysql_query("SET NAMES 'utf8'", $conn);
      mysql_query("SET CHARACTER SET 'utf8'", $conn);
    }
    else
    echo "Fehler beim speichern der Daten in der MySQL-Datenbank";
    ?>
    JPGraph:
    Code:
    <?php
    
    // JPGraph Library einbinden 
    include ("jpgraph/src/jpgraph.php");
    include ("jpgraph/src/jpgraph_bar.php");
    
    // Datenbank-Zugriff, -Abfrage und Array füllen
    include("db-config.php");
    //$sql = "SELECT * FROM Gas";
    //$sql = "SELECT GZStand FROM Gas ORDER BY id DESC LIMIT 13";
    $sql = "SELECT DATE_FORMAT(datumzeit,'%d.%m.%Y') AS DATUM, DATE_FORMAT(datumzeit,'%H:%i') AS ZEIT FROM Gas WHERE `datumzeit` >= date_sub(now(), interval 24 hour) AND `datumzeit` <= now()  GROUP BY DATE_FORMAT(datumzeit, '%Y-%m-%d %H') ORDER BY datumzeit DESC";
    
    $result = mysql_query($sql) OR die(mysql_error()); 
    
    $i=0; 
    while ($array=mysql_fetch_array($result)) { 
            $datum[$i]= strtotime($array[1]);
    	//$GZStand[$i]=$array[2];
    $i++; 
    }; 
    
    //$datay=$GZ;
    //$datax=$datum;
    
    // Setup the graph.
    $graph = new Graph(1090,240,"auto");
    $graph->img->SetMargin(60,20,20,40);
    //$graph->SetScale("textlin");
    $graph->SetScale("textlin");
    $graph->xaxis->SetTickLabels($datum);
    $graph->SetMarginColor("lightblue:1.1");
    $graph->SetShadow();
    
    // Set up the title for the graph
    $graph->title->Set("Bar gradient with left reflection");
    $graph->title->SetMargin(8);
    $graph->title->SetFont(FF_FONT1 ,FS_NORMAL,8);
    $graph->title->SetColor("darkred");
    
    //Achsenbeschriftung
    $graph->xaxis->title->Set("Tag");
    $graph->yaxis->title->Set("Verbrauch");
    
    //Verschieben der y-Achsenbeschriftung
    $graph->yaxis->SetTitleMargin(50);
    
    //Werte festlegen
    $sql = "SELECT GZStand FROM Gas ORDER BY id DESC LIMIT 13";
    
    $result = mysql_query($sql) OR die(mysql_error()); 
    
    $i=0; 
    while ($array=mysql_fetch_array($result)) { 
            //$datum[$i]= strtotime($array[1]);
    	$GZStand[$i]=$array[2];
    $i++; 
    }; 
    
    // Arrays umsortieren
    $datum = array_reverse($datum);
    
    //Umwandlung in Graph
    $bplot = new BarPlot($GZStand);
    
    //Balkenfarbefarbe (JP Graph PreErstellung des Graphen
    $bplot->SetFillColor('red');
    
    //ODER es ist auch ein Farbüberlauf möglich (1. FaAusrichtung)
    $bplot->SetFillGradient("red","yellow",GRAD_HOR);
    //Anzeige der Werte des jeweiligen Balkens
    $bplot->value->Show();
    //y-Fläche erhöhen um %
    $graph->yaxis->scale->SetGrace(35);
    //Um die angezeigten Werte über den Graphen zu dreSchriftart festgelegt werden
    $bplot->value->SetFont(FF_TIMES);
    
    //oder die Farbe:
    $bplot->value->SetColor("darkred");
    //Schatten ist ebenfalls möglich
    $bplot->SetShadow();
    
    //x und y-Achse Farben festlegen
    $graph->xaxis->SetColor("red");
    $graph->yaxis->SetColor("darkgreen");
    //Gegeben falls Schatten einrichten
    $graph->SetShadow();
    //Graph in die Grafik einfügen
    $graph->Add($bplot);
    
    // Graph ausgeben
    $graph->Stroke();
    ?>
    Aber damit kommt nicht das gewünschte raus.
    Kann mir jemand Helfen ?
    Ich bitte aber gleich um Nachsicht, bin sehr Neu auf dem Gebiet PHP usw.

    Vielen Dank.
    Gruß
    Stefan

  • #2
    Hallo Stefan,

    Zitat von Cetax Beitrag anzeigen
    Nun die FRAGE, wie kann ich die Datenbank abfragen, das mir nur der Verbrauch vom heutigen Tag angezeigt wird?
    Die Spalte datumzeit in deiner Datenbank sieht nicht nach einem MySQL DATETIME-Typ aus. Kann es sein, dass die vom Typ VARCHAR ist und du dort den einfach den String reinschreibst, den dein Gaszähler liefert? Wenn ja, kannst du nicht direkt mit den Datumsfunktionen (wie DATE_FORMAT) arbeiten, weil die davon ausgehen, dass das Argument als MySQL Datums/Zeit-Typ vorliegt.

    Versuch mal, die Zählerzeit vor dem Eintragen in die DB zu einer echten MySQL-DATETIME-Angabe zu konvertieren und den Spaltentyp entsprechend anzupassen.

    Gruß,

    Amica
    [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
    Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
    Super, danke!
    [/COLOR]

    Kommentar


    • #3
      Zitat von AmicaNoctis Beitrag anzeigen
      Versuch mal, die Zählerzeit vor dem Eintragen in die DB zu einer echten MySQL-DATETIME-Angabe zu konvertieren und den Spaltentyp entsprechend anzupassen.
      Wenn es wider Erwarten mit dem Konvertieren nicht klappen sollte, kannst Du auch beim Auslesen mit der MySQL STR_TO_DATE() Funktion versuchen. Die Datumsfunktionen von MySQL findest Du hier: MySQL :: MySQL 5.5 Reference Manual :: 12.7 Date and Time Functions
      MM Newmedia | MeinBlog

      Kommentar


      • #4
        Hallo,
        sorry das ich erst jetzt Antworte, aber wir hatten lange kein Internet... (blöde Telekomiker).

        So, hier mal den PHP Teil,der die Werte in die DB schreibt:
        PHP-Code:
        <?php

        define
        ("KEY","123456");
         
        include(
        "db-config.php");
         
        if(isset(
        $_GET['key']))
        {
          if(
        $_GET['key'] == KEY)
          {
            if(isset(
        $_GET['T1']))
            {
              
        $GZ mysql_real_escape_string($_GET['T1']);
              
        $DATUM date("Y-m-d H:i:s");
         
              
        $result mysql_query("INSERT INTO Gas (datumzeit, GZStand)
                      VALUES('"
        .$DATUM."', '".$GZ."') ") or die(mysql_error());
         
              if(
        mysql_affected_rows() == 1)
              {
                
        $result "Gaswert gespeichert";
              } else 
        $result "Fehler beim speichern der Daten in der MySQL-Datenbank";
            } else 
        $result "Kein Wert übergeben";
          } else 
        $result "Falscher Key";
        } else 
        $result "Kein Key übergeben";
         
        print_r($result);
        ?>
        Wie mache ich denn jetzt aus dem "$DATUM = date("Y-m-d H:i:s");" ein "MySQL DATETIME-Typ" ?

        Mit sowas "CURDATE()" und "CURTIME()" ?
        Aber wohin geschrieben und wie ?

        Vielen Dank für die schnelle Hilfe

        Gruß
        Stefan
        Zuletzt geändert von Cetax; 23.12.2012, 16:08.

        Kommentar


        • #5
          Zitat von Cetax Beitrag anzeigen
          Wie mache ich denn jetzt aus dem "$DATUM = date("Y-m-d H:i:s");" ein "MySQL DATETIME-Typ" ?
          Vom Format her sieht das schonmal gut aus. MySQL kann damit etwas anfangen. Warum hast du es dann bei deiner Anfrage als "d-m-y-h-i-s" (19-12-12-13-08-05) angegeben, womit MySQL nichts hätte anfangen können?

          Jetzt muss die Spalte „datumzeit“ nur noch vom Typ DATETIME sein, dann hast du es.

          Amica
          [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
          Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
          Super, danke!
          [/COLOR]

          Kommentar


          • #6
            Hallo Amica,
            vielen Dank für deine schnelle Hilfe.
            ich habe es jetzt geändert (Habe ich irgendwie übersehen).
            Habe aus
            PHP-Code:
            $sql "SELECT DATE_FORMAT(datumzeit,'%d.%m.%Y') ... 
            Das gemacht
            PHP-Code:
            $sql "SELECT DATE_FORMAT(datumzeit,'%Y.%m.%d') ... 
            Aber das
            Jetzt muss die Spalte „datumzeit“ nur noch vom Typ DATETIME sein, dann hast du es.
            Ok, habe geschaut ist DATETIME.

            Wenn ich die seite so auf rufe, sehe ich leider immer noch kein Balkendiagramm...
            Wie kann ich denn nun den Tagesverbrauch anzeigen lassen mit JPGraph ?
            Man ist das schwer, ich habe mir das ein bischen einfacher vergestellt...

            Gruß
            Stefan
            Zuletzt geändert von Cetax; 27.12.2012, 01:28. Grund: Korrektur

            Kommentar


            • #7
              Weiß keiner weiter ?

              Oder alle noch im Weihnachts-Urlaub ...

              Kommentar


              • #8
                Zitat von Cetax Beitrag anzeigen
                Wenn ich die seite so auf rufe, sehe ich leider immer noch kein Balkendiagramm...
                Was siehst du denn stattdessen? Stell dir einfach mal vor, du müsstest es jemandem erklären, der nicht vor deinem Rechner sitzt und nicht sehen kann, was du machst
                [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
                Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
                Super, danke!
                [/COLOR]

                Kommentar


                • #9
                  Hallo AmicaNoctis,

                  Zitat von AmicaNoctis Beitrag anzeigen
                  Was siehst du denn stattdessen? Stell dir einfach mal vor, du müsstest es jemandem erklären, der nicht vor deinem Rechner sitzt und nicht sehen kann, was du machst
                  Hast ja recht...
                  Hätte ich ja selbst drauf kommen können...

                  Schreibe und mache mal Bilder ....

                  Kommentar


                  • #10
                    so....
                    habe Fotos gemacht, entwickelt und zu Dropbox gebracht....
                    Nee mal im ernst, also ich sehe nun schon mal mehr, aber immer noch kein Balkendiagramm.
                    Irgendwo ist der Wurm drin und verstehe es nicht....

                    Schaut mal bitte drauf, so sieht es aus was ich auf meinem Monitor sehe:
                    https://dl.dropbox.com/u/80052077/Te...g/SQL_Gas4.png

                    Das ist der JPGrapg-Code:
                    https://dl.dropbox.com/u/80052077/Te...g/Gas_Bar2.php

                    Falls Ihr noch irgendwelche Infos braucht, bitte sagen...

                    Danke !!

                    Kommentar


                    • #11
                      Lass dir doch mal das array ausgeben mit welchem du die Daten für den graph übergibst.
                      Also das heißt das $datay und schau ob da überhaupt die Werte drin sind die du erwartest.

                      Kommentar


                      • #12
                        Hi,
                        das habe ich verswucht, aber irgendwie kommt da nicht das raus.
                        Ich weiss aber auch nicht, ob das so richtig ist:
                        PHP-Code:
                        <?php

                        // Datenbank-Zugriff, -Abfrage und Array füllen
                        include("db-config.php");

                        $sql "SELECT DATE_FORMAT(datumzeit,'%Y.%m.%d') AS DATUM, DATE_FORMAT(datumzeit,'%H:%i') AS ZEIT FROM Gas WHERE `datumzeit` >= date_sub(now(), interval 24 hour) AND `datumzeit` <= now()  GROUP BY DATE_FORMAT(datumzeit, '%Y-%m-%d %H') ORDER BY datumzeit DESC";

                        $result mysql_query($sql) OR die(mysql_error()); 

                        $i=0
                        while (
                        $array=mysql_fetch_array($result)) { 
                            
                        $id[$i]=$array[0];
                                
                        $datum[$i]= strtotime($array[1]);
                            
                        $GZStand[$i]=$array[2];
                        $i++; 
                         
                        }
                         echo 
                        $id .'<br>';
                         echo 
                        $GZStand .'<br>';
                         echo 
                        $datum .'<br>';

                        ?>
                        So sieht die DB Struktur aus:
                        https://dl.dropbox.com/u/80052077/Te...g/SQL_Gas6.png

                        So sieht es aus:
                        https://dl.dropbox.com/u/80052077/Te...g/SQL_Gas5.png

                        Vielen Dank

                        Gruß
                        Stefan

                        Kommentar


                        • #13
                          Arrays muss man mit print_r oder var_dump ausgeben.
                          [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
                          Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
                          Super, danke!
                          [/COLOR]

                          Kommentar


                          • #14
                            oh man.... Manchmal ist man einfach zu blöd...
                            Also, jetzt sehe ich was, aber nur Datum und Uhrzeit, aber nicht den Gasverbrauch...

                            https://dl.dropbox.com/u/80052077/Te...g/SQL_Gas7.png

                            Also stimmt was nicht mit der SQL abfrage...
                            PHP-Code:
                            <?php

                            // Datenbank-Zugriff, -Abfrage und Array füllen
                            include("db-config.php");

                            $sql "SELECT DATE_FORMAT(datumzeit,'%Y.%m.%d') AS DATUM, DATE_FORMAT(datumzeit,'%H:%i') AS ZEIT FROM Gas WHERE `datumzeit` >= date_sub(now(), interval 24 hour) AND `datumzeit` <= now()  GROUP BY DATE_FORMAT(datumzeit, '%Y-%m-%d %H') ORDER BY datumzeit DESC";

                            $result mysql_query($sql) OR die(mysql_error()); 

                            $i=0
                            while (
                            $array=mysql_fetch_array($result)) { 
                                
                            $id[$i]=$array[0];
                                    
                            $datum[$i]= strtotime($array[1]);
                                
                            $GZStand[$i]=$array[2];
                            $i++; 
                             
                             
                            print_r ($array[0] .'&nbsp;');
                             
                            print_r ($array[1] .'&nbsp;');
                             
                            print_r ($array[2] .'<br>');
                            }
                            ?>
                            Aber was ? Wie frage ich das denn ab ???

                            Kommentar


                            • #15
                              Du fragst den Gasstand nicht ab...

                              Kommentar

                              Lädt...
                              X