Ankündigung

Einklappen
Keine Ankündigung bisher.

Simple SQL-Abfrage funktioniert nicht ..

Einklappen

Neue Werbung 2019

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

  • Simple SQL-Abfrage funktioniert nicht ..

    .. finde den Fehler nicht. Kann mir wer helfen?

    Who could help me here. Am parsing values with Sessions ... put them into vars and try to echo them ..
    It all works fine with :

    PHP-Code:
    $sql "SELECT * FROM `customers`
          WHERE   c_company = '
    $cname'
    "

    but in the moment when I extend the WHERE-condition LIKE THIS
    PHP-Code:
    $sql " SELECT * FROM `customers`
                 WHERE
            c_company = '
    $cname'   AND    c_name = '$pname'
    "
    ;

     .. 
    the page stays blank 


    Here is the whole php-file:


    PHP-Code:
    <?php   
    session_start
    ();
    $cname $_SESSION["con"];
    $fname $_SESSION["fan"];
    $pname $_SESSION["prn"];   
    ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <!-- TemplateBeginEditable name="doctitle" -->
    <title>Fast Fertig!</title>
    </head>
    <body>

    PHP-Code:
    <?php
    $server 
    'www.website.at';
    $user 'user';
    $pw 'pw';
    $db 'database';

    $verbindung mysqli_connect($server$user$pw);

    if (
    $verbindung){
             
    mysqli_select_db($verbindung$db);
                if (
    mysqli_error($verbindung)){
                echo 
    'Fehler: '.mysqli_error($verbindung);
               
                }else {
                     
                          
    $sql "
                          SELECT * FROM `customers`
                          WHERE
                          c_company = '
    $cname'   AND
                          c_name = '
    $pname
                          "
    ;
                             
                 
    $abfrage mysqli_query($verbindung$sql);
                               while(
    $ev_rec mysqli_fetch_assoc($abfrage)){
                                     echo 
    '<div>';
                                        echo 
    '<div>';
                                            echo 
    'Kundennummer: 1963'.$ev_rec['iddb_customer'].'<br>';   
                                             echo 
    '<div class="r_align">Firma: '.$ev_rec['c_company'].'</div>';
                                             echo 
    '<div class="r_align">Name: '.$ev_rec['c_famname']." ".$ev_rec['c_name'].'</div>';
                                             echo 
    '<br>';
                                          echo 
    '</div>';
                                     echo 
    '</div>';
                               }
                     
                     
                      
    mysqli_free_result($abfrage);
                      }
                 }else {
                    
                    echo 
    'Verbindungsfehler: ' mysqli_connect_error($verbindung);
                
             }
              
    mysqli_close($verbindung);

             
              
    session_destroy();
    ?>

    </body>
    </html>

  • #2
    Richtig debuggen

    1. Man bemerkt, dass ein Skript nicht das tut, was es soll.
    2. Man schreibt an den Anfang des Scriptes die Zeile: error_reporting(-1);
    3. Man verwendet ini_set('display_errors', true); damit die Fehler auch angezeigt werden.
    4. Man versucht, die Stelle die daran Schuld sein kann, schonmal einzugrenzen. Falls dies nicht geht, wird zunächst das komplette Skript als fehlerhaft angesehen.
    5. An markanten Stellen im Skript lässt man sich wichtige Variableninhalte ausgeben und ggf. auch in bedingten Anweisungen eine kurze Ausgabe machen, um zu überprüfen, welche Bedingung ausgeführt wurde. Wichtig bei MySQL Fehlern (...not a valid MySQL result resource...): mysqli_error() verwenden oder Abfrage ausgeben und zb mit phpmyadmin testen.
    6. Schritt 5 wird so lange wiederholt, bis Unstimmigkeiten im Skript auffallen
    7. Damit hat man das Problem (Unstimmigkeit) gefunden und kann versuchen diese zu beheben. Hierzu dienen dann die PHP-Dokumentation und andere Quellen als Ratgeber.
    8. Lässt sich das konkrete Problem trotzdem nicht beheben, kann man in Foren um Rat fragen.
    9. Das Programm läuft und man kann die Debug-Ausgaben wieder entfernen.
    Die Deutsche Rechtschreibung ist Freeware! Du darfst sie kostenlos nutzen, allerdings ist sie nicht Open Source, d.h. Du darfst sie nicht verändern oder in veränderter Form veröffentlichen.

    Kommentar

    Lädt...
    X