sql >> Database >  >> RDS >> Mysql

Maak verschillende resultatensets met één resultaatset

Om een ​​resultatenset in een zoekopdrachtvoorwaarde voor een reeks zoekopdrachten te gebruiken, heb je een cursor nodig.

Bekijk de basisprincipes van cursorgebruik hier en in de docs

DELIMITER $$

CREATE PROCEDURE group_results_by_date 
BEGIN

 DECLARE v_finished INTEGER DEFAULT 0;
 DECLARE cdate DATE DEFAULT "2015-01-01";

 -- declare cursor for getting list of dates
 DEClARE date_cursor CURSOR FOR 
    SELECT DISTINCT (date) FROM yourtable;

 -- declare NOT FOUND handler
 DECLARE CONTINUE HANDLER 
        FOR NOT FOUND SET v_finished = 1;

 OPEN date_cursor;

 get_content: LOOP

 FETCH date_cursor INTO cdate;

 IF v_finished = 1 THEN 
 LEAVE get_content;
 END IF;

 -- Select query for different dates
 Select count, date, content from yourtable where date = cdate;

 END LOOP get_content;

 CLOSE date_cursor;

END$$

DELIMITER ;

U kunt deze procedure oproepen door

CALL group_results_by_date();



  1. Android Sqlite-prestaties

  2. Records selecteren in volgorde van ouder-ID

  3. NLSSORT() Functie in Oracle

  4. Hoe kies ik tussen de 1e dag van de huidige maand en de huidige dag in MySQL?