sql >> Databasteknik >  >> RDS >> Mysql

Skapa olika resultatuppsättningar med en resultatuppsättning

För att använda en resultatuppsättning i ett frågevillkor för en uppsättning frågor behöver du en markör.

Kolla in grunderna för marköranvändning här och i dokumenten

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 ;

Du kan anropa denna procedur genom att

CALL group_results_by_date();



  1. PLS-00302:komponent måste deklareras- Kan inte lösas

  2. MySQL LEFT JOIN endast 1 rad beroende på MAX()-värdet

  3. delvis resultat från en långvarig SELECT-fråga?

  4. mysqli_result::gratis öka användningen av php-minne