Hilfe gebraucht......

Godsilla

Grünschnabel
Ich habe eine altes Script, was ich umschreiben möchte in PDO und habe da meine Probleme:
SQL:
    $sql = "SELECT
                        LAST_INSERT_ID()
           ";
    $result = mysql_query($sql);
    $ID = mysql_result($result,0);

    $sql = "INSERT INTO
                        User_Rechte
                        (UserID,
                         Recht
                        )
            VALUES
                        ('".$ID."',
                         'Adminbereich'
                        )
           ";
if(mysql_query($sql))
         echo "<p>Recht 'Adminbereich' erfolgreich zu User 'admin' hinzugef�gt</p>";
else {
         echo "<p>Recht 'Adminbereich' konnte nicht zu User 'admin' zugeordnet werden</p>";
         echo "<h2>Query</h2>\n";
         echo "<pre>".$sql."</pre>\n";
         echo "<h2>Fehlermeldung</h2>";
         echo "<p>".mysql_error()."</p>";
         die();
}

Ich hoffe mir kann jemand helfen dabei.
 
Ich habe dies versucht:
SQL:
try{
    $sql = "SELECT
                        LAST_INSERT_ID()
           ";
    $connid->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $result = $connid->prepare($sql);
    $ID = $result->fetchAll();
    $sql = "INSERT INTO
                        User_Rechte
                        (UserID,
                         Recht
                        )
            VALUES
                        ('".$ID."',
                         'Adminbereich'
                        )
           ";
    $connid->exec($sql);
         echo "<p>Recht 'Adminbereich' erfolgreich zu User 'admin' hinzugef�gt</p>";
} catch (PDOException $fehler) {
         echo "<p>Recht 'Adminbereich' konnte nicht zu User 'admin' zugeordnet werden</p>";
         echo "<h2>Query</h2>\n";
         echo "<pre>".$sql."</pre>\n";
         echo "<h2>Fehlermeldung</h2>";
         echo "<p>".$fehler->getMessage()."</p>";
         die();
}

Aber leider gibt er mir als ID eine 0, ansatt 1.
 
Die SQL-Funktion LAST_INSERT_ID() gibt den ersten automatisch generierten Wert zurück, der bei einer INSERT-Anweisung in eine AUTO_INCREMENT-Spalte eingefügt wurde. Ein Insert sehe ich aber erst danach.

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.
 

Neue Beiträge

Zurück