Problem mit Konstruktor

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

  • Problem mit Konstruktor

    Hallo
    habe ein kleines Problem in einer PHP Klasse.
    class Aufgaben extends Conn
    {
    public function __construct()
    {

    }
    function uebersicht()
    {
    $query = "SELECT aufgabenID, titel, beschreibung, prio, DATE_FORMAT(beginn,'%d.%m.%Y') AS beginn, DATE_FORMAT(termin,'%d.%m.%Y') AS termin FROM ri_aufgaben ORDER BY termin DESC";
    $result = $this->query($query);
    if (mysql_num_rows($result) > 0)
    {
    echo "TEST";
    }
    }

    }
    Wenn der Konstruktor vorhanden ist, kommt eine MySql Query Fehlermeldung, als wäre der Select nicht korrekt.
    Kaum ist der Konstruktor ausgeklammert klappt alles. An was kann das liegen?
    Danke für die Hilfe

  • #2
    Hallo,

    das liegt bestimmt daran, dass in diesem Falle der Konstruktor der Elternklasse ausgeblendet wird. Ohne Konstruktor wird der Elternkonstruktor benutzt und alles ist in Ordnung. Mit Konstruktor muss dieser mit [FONT="Courier New"]parent::__construct()[/FONT] den Elternkonstruktor explizit aufrufen.

    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
      Gelöst

      Super, genau das war's. Wieder was gelernt. Vielen Dank Amica.
      Gruss maramiro

      Kommentar


      • #4
        Da aber eh nix im Konstruktor steht, kannst du den in der Kindklasse auch einfach weglassen …*dann wird automatisch der nächst-höhere verwendet.
        [FONT="Helvetica"]twitter.com/unset[/FONT]

        Shitstorm Podcast – Wöchentliches Auskotzen

        Kommentar


        • #5
          Der Konstruktor soll später nicht leer sein. Trotzdem Danke für den Tipp. So langsam verstehe ich den Zusammenhang der Konstruktoren in vererbten Klassen.

          Kommentar


          • #6
            PHP-Code:
            class Aufgaben extends Conn 
            Da lauert ein schwerer Design Fehler.

            "Aufgaben" ist ein Datenmmodell und "Conn" doch sicher eine Datebankverbindung. Oder?

            "extends" bilden immer nur "ist eine" Beziehungen aus.
            Hier also: Aufgaben ist eine Datenbank Verbindung.
            Für mich hört sich das falsch an.

            Besser:
            Übergib dem Datenmodell das, was es benötigt, per Konstruktor oder Setter.
            Wir werden alle sterben

            Kommentar


            • #7
              Jedenfalls sofern man mit Models arbeitet –*was man tun sollte aber nicht muss.
              [FONT="Helvetica"]twitter.com/unset[/FONT]

              Shitstorm Podcast – Wöchentliches Auskotzen

              Kommentar


              • #8
                Mal schauen ob ich das verstanden habe (?):

                PHP-Code:
                class Conn
                {
                    var 
                $connect;
                    var 
                $res;
                    var 
                $host DB_HOST;
                    var 
                $user DB_USER;
                    var 
                $password DB_PW;
                    var 
                $dbname DB_DATABASE;
                    public function 
                __construct ()
                    {
                        if(!
                $this->connect mysql_connect($this->host$this->user$this->password))
                        {
                            echo 
                "Verbindung zu Mysql fehlgeschlagen...";
                        }
                        
                //return $this->conn;
                        
                if (!mysql_select_db($this->dbname$this->connect))
                        {
                            echo 
                "Datenbank konnte nicht verbunden werden...";
                        }
                    }
                    function 
                query($sql){
                        if (!
                $this->res mysql_query($sql$this->connect))
                        {
                            echo 
                "Query konnte nicht gesendet werden...";
                        }
                        return 
                $this->res;
                    }

                PHP-Code:
                class Aufgaben
                {
                    public function 
                __construct()
                    {
                         
                    }
                    function 
                uebersicht()
                    {
                        
                $conn = new Conn();
                        
                $query "SELECT aufgabenID, titel, beschreibung, prio, DATE_FORMAT(beginn,'%d.%m.%Y') AS beginn, DATE_FORMAT(termin,'%d.%m.%Y') AS termin FROM ri_aufgaben ORDER BY termin DESC";
                        
                $result $conn->query($query);
                        if (
                mysql_num_rows($result) > 0)
                        {
                            echo 
                'TEST';    
                        }
                    }
                    

                Zuletzt geändert von maramiro; 28.09.2009, 14:31.

                Kommentar


                • #9
                  Bitte benutze die PHP-Tags des Forums, andernfalls ist der Quelltext so gut wie unlesbar.
                  [FONT="Helvetica"]twitter.com/unset[/FONT]

                  Shitstorm Podcast – Wöchentliches Auskotzen

                  Kommentar


                  • #10
                    Hallo,

                    bitte ändere deinen Beitrag und benutze die PHP-Tags für den PHP-Quelltext.

                    Die Connection würde ich als Membervariable speichern und im Konstruktor instanziieren und nicht in jeder Methode einzeln.

                    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

                    Lädt...
                    X