Heim > Datenbank > MySQL-Tutorial > Wie behebe ich „Fehler 1329: Keine Daten abgerufen, ausgewählt oder verarbeitet' in gespeicherten MySQL-Prozeduren?

Wie behebe ich „Fehler 1329: Keine Daten abgerufen, ausgewählt oder verarbeitet' in gespeicherten MySQL-Prozeduren?

Susan Sarandon
Freigeben: 2024-10-25 19:11:02
Original
277 Leute haben es durchsucht

How to Resolve

So beseitigen Sie „Fehler 1329: Keine Daten abgerufen, ausgewählt oder verarbeitet“

Beim Ausführen gespeicherter Prozeduren, die keine Werte zurückgeben, Benutzer stoßen möglicherweise auf „Fehler 1329: Keine Daten – null Zeilen abgerufen, ausgewählt oder verarbeitet.“ Um dieses Problem zu beheben, führen Sie die folgenden Schritte aus:

Betrachten Sie die folgende gespeicherte Prozedur:

CREATE PROCEDURE `testing_proc`()  
    READS SQL DATA  
BEGIN  
    DECLARE done INT DEFAULT 0;
    DECLARE l_name VARCHAR(20);
    DECLARE my_cur CURSOR FOR
        SELECT name FROM customer_tbl;
    OPEN my_cur;
        my_cur_loop:
        LOOP FETCH my_cur INTO l_name;
            IF done = 1 THEN
                LEAVE my_cur_loop;
            END IF;
            INSERT INTO names_tbl VALUES(l_name);
        END LOOP my_cur_loop;
    CLOSE my_cur;
END
Nach dem Login kopieren

Der Fehler ist auf das Verhalten von MySQL zurückzuführen, eine Warnung anzuzeigen, selbst wenn sie behandelt wurde. Um dies zu verhindern, fügen Sie am Ende der Prozedur die folgende Zeile ein:

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
Nach dem Login kopieren

Alternativ können Sie eine „Dummy“-Anweisung hinzufügen, die eine Tabelle einbezieht und nach der Schleife erfolgreich ausgeführt wird, zum Beispiel:

SELECT name INTO l_name FROM customer_tbl LIMIT 1;
Nach dem Login kopieren

Dadurch wird die Warnung aufgrund eines Fehlers/seltsamen Verhaltens in MySQL gelöscht (siehe http://dev.mysql.com/doc/refman/5.5/en/show-warnings.html).

Das obige ist der detaillierte Inhalt vonWie behebe ich „Fehler 1329: Keine Daten abgerufen, ausgewählt oder verarbeitet' in gespeicherten MySQL-Prozeduren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage