根据要导入的行获取排名

时间:2018-09-18 23:40:53

标签: mysql variables cursor procedure

我需要以某种方式完成此操作,以便每当导入一个student_class并具有相关的部分时,它都应位于其特定的排名之下。

DROP PROCEDURE IF EXISTS sp_test;
Delimiter $$
CREATE PROCEDURE sp_Student_Classs1() 
BEGIN
DECLARE done, doneX int default 0; 
DECLARE var_Student_Class_IDX, var_importedX, var_SectionX, var_form_idX, rnX int;  -- curX variables;
DECLARE var_Student varchar(255);   
DECLARE curA CURSOR FOR select Student_id from temp_Students;
DECLARE continue handler FOR NOT FOUND SET done = 1;
Open curA;

WHILE (done = 0) do   -- curA while
FETCH NEXT FROM curA INTO var_Student;
if done = 0 then      -- curA if
drop table if exists temp_table;
set @create_imported =  concat('create table temp_table (select pp.Student_Class_ID, usi.imported, usi.Section, usi.form_id,  pp.last_update_date, ''null'' as rn ', 
        ' from Student_Classs pp left join ui_sections usi on usi.Instance_ID = pp.Student_Class_ID where pp.Student_ID = ', var_Student, ' order by pp.last_update_date)' );
        select @create_imported;      PREPARE stmt_name FROM @create_imported;     EXECUTE Stmt_name;     DEALLOCATE prepare stmt_name;
        begin
        declare curX CURSOR FOR select Student_Class_ID, imported, Section, form_id, rn from temp_table;
        DECLARE continue handler FOR NOT FOUND SET doneX = 1;
        open CurX;
        set doneX = 0; set @rn = 1;
        while (doneX = 0) do
        FETCH NEXT FROM curX into var_Student_Class_IDX, var_importedX, var_SectionX, var_form_idX, rnX;
        if doneX = 0 then 
        if (var_imported in (select SectionID from temp_table)) or (var_Section_X in (select imported from temp_table)) 
        then
        set @insertX = concat('update temp_table set rn = ', @rn, ' where Student_Class_ID = ',var_Student_Class_IDX);  select @insertX;
         PREPARE stmt_name FROM @insertX;     EXECUTE Stmt_name;     DEALLOCATE prepare stmt_name;
          else 
          set @rn = @rn+1;
          set @insertX = concat('update temp_table set rn = ', @rn, ' where Student_Class_ID = ',var_Student_Class_IDX);  select @insertX;        
        end if;
        end if;
        end while;
        close CurX;
        end;

我能够获得前3行的第一个等级1,但之后它会像2,3一样增加,但应该保持在2,2,2。凭什么我可以使此逻辑正确?

结果应如下所示:

Section Imported    Student_Class   Student form    Rank
720      (null)      630              111     4       1
935       493        584              111     5       1
493       720        733              111     6       1
38         6         988              111     4       2
6       (null)       986              111     3       2
459       38         531              111     2       2

265       (null)     704               25     3       1
547       (null)     692               25     1       2

您能帮我吗?

0 个答案:

没有答案