卷灰 发表于 2015-7-27 17:15:07

查询过慢,涉及以下sql语句,无头绪,该怎么优化的??

DELIMITER $$

USE `school`$$

DROP PROCEDURE IF EXISTS `system_teaPer_byteacher_split0417`$$

CREATE DEFINER=`schu`@`%` PROCEDURE `system_teaPer_byteacher_split0417`(
                                                        p_btime VARCHAR(100),
                                                        e_time VARCHAR(100),
                                                        p_gradeidStr VARCHAR(1000),
                                                        p_subjectidStr VARCHAR(1000),
                                                        p_clsIdStr VARCHAR(1000),
                                                        p_dcschool_id INT,
                                                        p_current_page INT,
                                                        p_page_size        INT,
                                                        p_sort_column VARCHAR(50),
                                                        OUT totalNum INT
                                                        )
BEGIN
        DECLARE tmp_sql VARCHAR(20000) DEFAULT '';
       
        SET tmp_sql = CONCAT("       
                SELECT cuser_id,teacher_name,courseCount,taskCount,endTaskCount
                ,IFNULL(compTaskPersonNum,0) compTaskPersonNum,IFNULL(personSumNum,0) personSumNum
                ,IFNULL(ROUND(IFNULL(compTaskPersonNum,0)/IFNULL(personSumNum,1)*100,2),'--') compBL
                ,IFNULL(coursePjSumScore,0) coursePjSumScore,coursePjStuCount
                ,IFNULL(ROUND(IFNULL(coursePjSumScore,0)/coursePjStuCount,2),0) coursePjScore
                FROM (
                -- 专题总数
                SELECT c.cuser_id,t.teacher_name,COUNT(DISTINCT c.course_id) courseCount,
                -- 专题下的任务总数(有效的)
                SUM((SELECT COUNT(DISTINCT task_id) FROM tp_task_info WHERE STATUS=1 AND course_id=c.course_id)) taskCount,
                -- 专题下已经结束的任务总数(有效的)
                SUM((
                        SELECT COUNT(DISTINCT ts.task_id) FROM tp_task_stat ts,tp_task_info t
                                WHERE ts.task_id=t.task_id
                                        AND t.course_id=c.course_id
                )) endTaskCount,
                -- 完成任务的总人数
                SUM((
                SELECT SUM(IFNULL(ts.done_person_num,0)) FROM tp_task_stat ts,tp_task_info t
                WHEREt.task_id=ts.task_id AND t.STATUS=1 ANDt.course_id=c.course_id))
               compTaskPersonNum,
                -- 应该参加完成任务的总人数
               SUM((
                SELECT SUM(IFNULL(ts.person_num,0)) FROM tp_task_stat ts,tp_task_info t
                WHEREt.task_id=ts.task_id AND t.STATUS=1 AND t.course_id=c.course_id))
                personSumNum
                -- 学生对专题的评价相加
                ,SUM((SELECT SUM(score) FROM score_info WHERE score_type=2 AND SCORE_OBJECT_ID=c.course_id)) coursePjSumScore
                -- 参与评价的学员总数
                ,SUM((SELECT COUNT(score_user_id) FROM score_info WHERE score_type=2 AND SCORE_OBJECT_ID=c.course_id)) coursePjStuCount
               FROM tp_course_info c,user_info u,teacher_info t
                WHERE u.user_id=c.cuser_id AND u.ref=t.user_id
                        AND c.LOCAL_STATUS=1 -- 有效的
                        AND EXISTS(
                                SELECT 1 FROM tp_j_course_class cc,class_info cla WHERE
                                course_id=c.course_id and cla.class_id=cc.class_id
                                AND begin_time BETWEEN '",p_btime,"' AND '",e_time,"'");   
                               
                               
                               
                               
                                       
       
        IF p_gradeidStr IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND cc.grade_id IN(",p_gradeidStr,") ");               
        END IF;
        IF p_subjectidStr IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND cc.subject_id IN(",p_subjectidStr,") ");       
        END IF;
       
        IF p_clsIdStr IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND cc.CLASS_ID IN(",p_clsIdStr,") ");       
        END IF;                               
       
        SET tmp_sql = CONCAT(tmp_sql,")");
        IF p_dcschool_id IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND c.dc_school_id=",p_dcschool_id);       
        END IF;       
        SET tmp_sql = CONCAT(tmp_sql,"
                        GROUP BY t.teacher_name,c.cuser_id
                ) t");
       
       
        IF p_sort_column IS NOT NULL THEN
                SET tmp_sql=CONCAT(tmp_sql," order by ",p_sort_column);
          ELSE
                SET tmp_sql=CONCAT(tmp_sql," ORDER BY compBL DESC");          
        END IF;
        IF p_page_size IS NOT NULL AND p_current_page IS NOT NULL THEN
                SET tmp_sql=CONCAT(tmp_sql," limit ",(p_current_page-1)*p_page_size,",",p_page_size);
        END IF;
       
        SET @tmp_sql = tmp_sql;
        PREPARE stmt FROM @tmp_sql;
        EXECUTE stmt;
        DEALLOCATE PREPARE stmt;
       
        SET tmp_sql = CONCAT("       
                -- 专题总数
                SELECT COUNT(distinct c.cuser_id) into @totalcount
               FROM tp_course_info c
                WHERE c.LOCAL_STATUS=1 -- 有效的
                        AND EXISTS(
                                SELECT 1 FROM tp_j_course_class cc,class_info cla WHERE
                                course_id=c.course_id and cla.class_id=cc.class_id
                                AND begin_time BETWEEN '",p_btime,"' AND '",e_time,"'");
        IF p_gradeidStr IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND cc.grade_id IN(",p_gradeidStr,") ");               
        END IF;
        IF p_subjectidStr IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND cc.subject_id IN(",p_subjectidStr,") ");       
        END IF;
        IF p_dcschool_id IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND cla.dc_school_id=",p_dcschool_id);       
        END IF;       
        IF p_clsIdStr IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND cc.CLASS_ID IN(",p_clsIdStr,") ");       
        END IF;                       
       
        SET tmp_sql = CONCAT(tmp_sql,")");
        IF p_dcschool_id IS NOT NULL THEN
                SET tmp_sql = CONCAT(tmp_sql," AND c.dc_school_id=",p_dcschool_id);       
        END IF;       
               
        SET @tmp_sql2 = tmp_sql;
        PREPARE stmt2 FROM @tmp_sql2;
        EXECUTE stmt2;
        SET totalNum = @totalcount;
    END$$

DELIMITER ;






wjzliu0064 发表于 2016-4-20 16:02:26

语句该优化的进行改造。存储过程在数据库中是必需的,是大数据、复杂关系数据处理的最好方式

DB大师 发表于 2015-7-28 09:17:08

生产上,不建议用存储过程!涉及相关业务的sql,得跟业务联系

卷灰 发表于 2015-7-28 09:43:33

生产上不用存储过程,那要存储过程干嘛滴……
这边业务全部在数据库端呢。

DB大师 发表于 2015-7-28 10:23:15

卷灰 发表于 2015-7-28 09:43
生产上不用存储过程,那要存储过程干嘛滴……
这边业务全部在数据库端呢。 ...

存储过程不建议用!让sql越简单越好!所以需要跟业务开发沟通,降低sql成本!提高DB性能

徐志定 发表于 2016-10-28 11:56:17

建议于业务沟通,优化一下需求,从中达到sql的可优化性
页: [1]
查看完整版本: 查询过慢,涉及以下sql语句,无头绪,该怎么优化的??