Mysql
 sql >> база данни >  >> RDS >> Mysql

Създайте различен набор от резултати, като използвате един набор от резултати

За да използвате набор от резултати в условие на заявка за набор от заявки, имате нужда от курсор.

Моля, разгледайте основите на използването на курсора тук и в документи

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 ;

Можете да извикате тази процедура чрез

CALL group_results_by_date();



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. каква е алтернативната функция mysql_list_tables() в php 5

  2. Предпочитан двигател на MySQL – MyISAM или InnoDB

  3. извличане на данни от mysql и изпращане на имейл

  4. MYSQL, много бавно подреждане по

  5. Изброяване на комбинации чрез SQL