mysql cursor-Schleife wählen

Ich Schreibe eine Prozedur, die gehen durch eine Tabelle und sammeln Sie alle top-10-Ergebnisse. Ich bin mit einem cursor dann das abrufen der Ergebnisse. Ich bin ein wenig stecken wie zum drucken der Ergebnisse. Ich verwendet eine select-Anweisung, um diese Ergebnisse, aber ich bin gesagt, dass es ein Fehler ist.

Jede Hilfe wird geschätzt. Danke.

create procedure plant_list()
begin
declare v_plant_id integer(5);
declare v_common_name varchar(30);
declare v_scientific_name varchar(20);


declare finished boolean default false;

declare cur_top_ten cursor for
    select P.plant_id, common_name, concat(genus, ' ', species)
    from plants P
        join plant_taxonomy PT on P.plant_id = PT.plant_id
    order by list_price desc
    limit 10
    ;

declare continue handler for not found set finished = true;

open cur_top_ten;
curloop: loop
    fetch cur_top_ten into v_plant_id, v_common_name, v_scientific_name;
    if finished then
        close cur_top_ten;
        set finished = false;
        leave curloop;
    end if

    select v_plant_id, v_common_name, v_scientific_name;


end loop curloop;

end;
#

InformationsquelleAutor user1682055 | 2012-09-30

Schreibe einen Kommentar