存储过程:
CREATE DEFINER=`root`@`%` PROCEDURE `Proc_PageCondition`(p_cloumns varchar(500),
p_tables varchar(400),
p_where varchar(4000),
p_order varchar(100),
p_pageindex int,
p_pagesize int,
out p_recordcount int,
out p_pagecount int)
begin
declare v_sqlcounts varchar(4000);
declare v_sqlselect varchar(4000); set v_sqlcounts = concat('select count(*) into @recordcount from ',p_tables,p_where); set @sqlcounts = v_sqlcounts;
prepare stmt from @sqlcounts;
execute stmt;
deallocate prepare stmt; set p_recordcount = @recordcount; set p_pagecount = ceiling((p_recordcount+0.0)/p_pagesize);
if p_pageindex <1 then
set p_pageindex = 1; end if; set v_sqlselect = concat('select ',p_cloumns,' from ',p_tables,p_where,if(p_order is not null,p_order,''),' limit ',(p_pageindex-1)*p_pagesize,' , ',p_pagesize); set @sqlselect = v_sqlselect;
prepare stmtselect from @sqlselect;
execute stmtselect;
deallocate prepare stmtselect;
end
调用过程:
set @p_cloumns = ' tr.id trainID,te.id eventID,u.uid userID,u.username,te.EventTime,te.EventLength,te.EventResult,tt.MaxSpeed,tt.MaxRotateSpeed,tt.ForeOrBack,te.EventStartFrameNumber,te.EventEndFrameNumber ';
set @p_tables = ' train_event te left join train_track tt on te.trackID=tt.id left join users u on u.uid=tt.TrainnerID left join training_record tr on te.TrainID=tr.id ';
set @p_where = ' where 1=1 ';
set @p_order = ' order by te.EventTime desc ';
set @p_pageindex = 1;
set @p_pagesize = 10;
set @p_recordcount = 0;
set @p_pagecount = 0;
call rigour_tennis_db.Proc_PageCondition(@p_cloumns, @p_tables, @p_where, @p_order, @p_pageindex, @p_pagesize, @p_recordcount, @p_pagecount);
select @p_cloumns, @p_tables, @p_where, @p_order, @p_pageindex, @p_pagesize, @p_recordcount, @p_pagecount;
注意:
起始页为pageIndex由1开始