`
kinkding
  • 浏览: 150658 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

统计总数的三种处理方式(SQL,JDBC,PROCEDUER)

阅读更多

1、最快的方式,一条SQL执行完毕(耗时92.266S):

SELECT COUNT(DV.DEVICE_ID)
  FROM PROD_FUNCTION_LOCATION FL,
       PROD_FL_DEVICE FD,
       PROD_DEVICE DV,
       PUB_CLASSIFY CL,
       (SELECT FL.VOLTAGE_LEVEL, FL.FUNCTION_LOCATION_CODE
          FROM PROD_FUNCTION_LOCATION FL
         WHERE FL.FUNCTION_LOCATION_NAME LIKE '%kV电压等级区%'
           AND FL.VOLTAGE_LEVEL > 1000
           AND FL.COPY_FLAG = 0) TBL
 WHERE DV.DEVICE_ID = FD.DEVICE_ID
   AND DV.VOLTAGE_LEVEL != TBL.VOLTAGE_LEVEL
   AND FD.DEVICE_CLASSIFY_CODE = CL.ALIAS_NAME
   AND CL.CODE LIKE '0101%'
   AND FD.FUNCTION_LOCATION_ID = FL.FUNCTION_LOCATION_ID
   AND FL.COPY_FLAG = 0
   AND FL.FUNCTION_LOCATION_CODE LIKE TBL.FUNCTION_LOCATION_CODE || '-%';

 

 

2、稍慢的方式,通过JDBC实现(133S):

package test.batch;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import test.DBUtil;

public class VolCount {

    private List<VO1> getList() {
        StringBuffer sbSQL = new StringBuffer(200);
        sbSQL.append("SELECT FL.VOLTAGE_LEVEL, FL.FUNCTION_LOCATION_CODE");
        sbSQL.append("      FROM PROD_FUNCTION_LOCATION FL");
        sbSQL.append("     WHERE FL.FUNCTION_LOCATION_NAME LIKE '%kV电压等级区%'");
        sbSQL.append("       AND FL.VOLTAGE_LEVEL > 1000");
        sbSQL.append("       AND FL.COPY_FLAG = 0");
        List<VO1> values = new ArrayList<VO1>();
        Connection conn = null;
        Statement stmt = null;
        ResultSet rs = null;
        try {
            // 设置数据库连接
            conn = DBUtil.getConnection();
            stmt = conn.createStatement();
            rs = stmt.executeQuery(sbSQL.toString());
            VO1 vo = null;
            while (rs.next()) {
                vo = new VO1();
                vo.vol = rs.getInt(1);
                vo.code = rs.getString(2);
                values.add(vo);
            }
        } catch (SQLException ex) {
            ex.printStackTrace();
        } finally {
            DBUtil.closeConnection(null, stmt, conn);
        }
        return values;
    }

    private int getSingleCount(int vol, String code) {
        StringBuffer sbSQL = new StringBuffer(411);
        sbSQL.append("SELECT COUNT(DV.DEVICE_ID)");
        sbSQL.append("  FROM PROD_FUNCTION_LOCATION FL,");
        sbSQL.append("       PROD_FL_DEVICE         FD,");
        sbSQL.append("       PROD_DEVICE            DV,");
        sbSQL.append("       PUB_CLASSIFY           CL");
        sbSQL.append(" WHERE DV.DEVICE_ID = FD.DEVICE_ID");
        sbSQL.append("   AND DV.VOLTAGE_LEVEL != ?");
        sbSQL.append("   AND FD.DEVICE_CLASSIFY_CODE = CL.ALIAS_NAME");
        sbSQL.append("   AND CL.CODE LIKE '0101%'");
        sbSQL.append("   AND FD.FUNCTION_LOCATION_ID = FL.FUNCTION_LOCATION_ID");
        sbSQL.append("   AND FL.COPY_FLAG = 0");
        sbSQL.append("   AND FL.FUNCTION_LOCATION_CODE LIKE ?");
        Connection conn = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        int value = 0;
        try {
            // 设置数据库连接
            conn = DBUtil.getConnection();
            pstmt = conn.prepareStatement(sbSQL.toString());
            pstmt.setInt(1, vol);
            pstmt.setString(2, code+"-%");
            rs = pstmt.executeQuery();
            if (rs.next()) {
                value = rs.getInt(1);
            }
        } catch (SQLException ex) {
            ex.printStackTrace();
        } finally {
            DBUtil.closeConnection(null, pstmt, conn);
        }
        return value;
    }

    class VO1 {

        int vol;

        String code;
    }

    public static void main(String[] args) {
        VolCount v = new VolCount();
        int total = 0;
        long time = System.currentTimeMillis();
        for(VO1 vo:v.getList()){
            total+=v.getSingleCount(vo.vol, vo.code);
        }
        System.out.println("total:"+total+" time:"+(System.currentTimeMillis()-time)/1000);
    }
}

 

3、最慢的方式,游标实现(在我的耐心范围内都没有出现结果):

 

CREATE OR REPLACE PROCEDURE P_DATA_AUDIT_DEV_VOL(DETAIL_ID  IN INTEGER,
                                                 COLLECT_ID IN INTEGER) IS
  V_TOTAL     INTEGER;
  V_TEMP      INTEGER;
  V_DETAIL_ID INTEGER;
  V_DATE      DATE;
  CURSOR C_OUTER IS
    SELECT FL.VOLTAGE_LEVEL, FL.FUNCTION_LOCATION_CODE
      FROM PROD_FUNCTION_LOCATION FL
     WHERE FL.FUNCTION_LOCATION_NAME LIKE '%kV电压等级区%'
       AND FL.VOLTAGE_LEVEL > 1000
       AND FL.COPY_FLAG = 0;

  CURSOR C_INNER(V_CODE VARCHAR2, V_VOL INTEGER) IS
    SELECT COUNT(DV.DEVICE_ID) COUNT
      FROM PROD_FUNCTION_LOCATION FL,
           PROD_FL_DEVICE         FD,
           PROD_DEVICE            DV,
           PUB_CLASSIFY           CL
     WHERE DV.DEVICE_ID = FD.DEVICE_ID
       AND DV.VOLTAGE_LEVEL != V_VOL
       AND FD.DEVICE_CLASSIFY_CODE = CL.ALIAS_NAME
       AND CL.CODE LIKE '0101%'
       AND FD.FUNCTION_LOCATION_ID = FL.FUNCTION_LOCATION_ID
       AND FL.COPY_FLAG = 0
       AND FL.FUNCTION_LOCATION_CODE LIKE V_CODE || '-%';
BEGIN
  V_TOTAL     := 0;
  V_TEMP      := 0;
  V_DETAIL_ID := DETAIL_ID;
  V_DATE      := SYSDATE;

  FOR O_REC IN C_OUTER LOOP
    FOR I_REC IN C_INNER(O_REC.FUNCTION_LOCATION_CODE, O_REC.VOLTAGE_LEVEL) LOOP
      DBMS_OUTPUT.PUT_LINE('COUNT'||I_REC.COUNT);
      V_DETAIL_ID := V_DETAIL_ID + I_REC.COUNT;      
    END LOOP;
  END LOOP;
  
  DBMS_OUTPUT.PUT_LINE('V_DETAIL_ID:' || V_DETAIL_ID || ' TIME:' ||
                       TO_NUMBER(SYSDATE - V_DATE) * 24 * 60 * 60 || 's');
EXCEPTION
  WHEN OTHERS THEN
    IF C_INNER%ISOPEN THEN
      CLOSE C_INNER;
    END IF;
    IF C_OUTER%ISOPEN THEN
      CLOSE C_OUTER;
    END IF;
END;
/

 

分享到:
评论

相关推荐

    mysql procedure源码

    MySQL存储过程是一种预编译好的SQL脚本,它可以接受输入参数、返回单个或多个结果,并且能够包含复杂的流程控制逻辑。存储过程可以被视作数据库的一个函数,可以在不同的应用程序中重复调用,从而简化开发工作并提高...

    学习使用存储过程(Stored Procedure)

    存储过程是一种预先编译并存储在数据库中的SQL脚本,它可以接受输入参数,并返回结果集或执行特定操作。几乎所有主流的大型数据库管理系统如Oracle、Microsoft SQL Server等均支持存储过程,而像MS Access这样的轻量...

    SQL Server 2005 创建简单的存储过程–总结分析

    最近由于工作需要,简单了解了下SQL Server 2005 数据库创建简单的在存储过程。一、首先说明如何创建存储过程: CREATE PROCEDUER my_pro @inputDate varchar ,//声明输入变量 @Result varchar(255) output //声明...

    国民经济行业分类与国际标准行业分类(ISIC+Rev.4)的对照和匹配(供参考).docx

    国民经济行业分类与国际标准行业分类(ISIC+Rev.4)的对照和匹配(供参考).docx

    网络助手工具(亲测好用)

    网络助手工具(亲测好用)

    013基于混合整数规划的电池容量优化 不能运行.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    HTML5实现的微信大转盘抽奖特效源码.zip

    这是一款基于jQuery+HTML5实现的微信大转盘抽奖效果源码,是一款可配置奖品抽奖的jQuery大转盘抽奖代码,可实现点击按钮转轮旋转实现抽奖功能,效果逼真自然,是一款非常优秀的特效源码

    自动驾驶控制-基于MPC的速度控制仿真 matlab和simulink联合仿真,基于mpc算法的速度控制,跟踪阶跃形式的速度和正弦形式的速度

    自动驾驶控制-基于MPC的速度控制仿真 matlab和simulink联合仿真,基于mpc算法的速度控制,跟踪阶跃形式的速度和正弦形式的速度。

    求解 2D 和 3D 分数矢量亥姆霍兹方程,用于非刚性图像配准Matlab代码.rar

    求解 2D 和 3D 分数矢量亥姆霍兹方程,用于非刚性图像配准Matlab代码.rar

    springboot103抗疫物资管理系统.zip

    springboot103抗疫物资管理系统,含有完整的源码和报告文档

    这是2023年华南理工大学机器人校内赛五山五狼—车车难造队的机械建模开源,我是本队机械建模队员杨欣然_-.zip

    这是2023年华南理工大学机器人校内赛五山五狼—车车难造队的机械建模开源,我是本队机械建模队员杨欣然_-

    将多个图像显示为子图的蒙太奇Matlab代码.rar

    将多个图像显示为子图的蒙太奇Matlab代码.rar

    基于labview的删除选定文件源码.zip

    labview源码参考示例,可供参考学习使用

    高维数据分析作业:图理论与矩阵范数应用(网络分析与社区检测)

    内容概要:本文档主要聚焦于2024年秋季学期高维数据分析课程的第六次作业,涉及多个关于复杂网络分析的重要概念和技术。具体涵盖:基于图论的基本证明如节点度与共同邻居的数学表达形式;对网络社区结构进行划分,并通过模态性公式评价这种划分的效果;针对实际社交网络数据集利用随机块模型和社会经济回报模型(SCORE)来进行高效的社区识别任务;以及深入探讨了矩阵的核范数及其与谱范数间的关系,强调了它们在解决现实生活中大型稀疏矩阵问题方面的重要性。 适合人群:面向正在学习数据挖掘、机器学习等相关专业的大三及以上的学生,特别是有兴趣深入了解图论及其在网络科学中具体应用的研究人员。 使用场景及目标:该文档用于帮助学生更好地掌握高维数据分析技巧,在实际项目实践中提高解决问题的能力。通过本练习可以加深对于社交网络构建、模块化计算方法的认识,同时也能加强对线性代数里关键概念的理解。这对于准备从事数据分析相关工作或进一步深造的同学非常有益。 其他说明:这份PDF材料包含了大量详细的数学推导步骤,以及具体的评分标准和作业完成时间限制(截止日期:12月29日星期日晚上十点)。为了更好地完成这门课的任务,建议配合教科书和其他参考资料一起使用,鼓励学生积极思考每个问题背后的原理。

    教育培训机构劳动合同.doc

    教育培训机构劳动合同

    到2023!地级市绿色专利获取申请数量 1990-2023 免费分享!

    ①数据来源:自己从cnrds数据库下载的原始数据,未做任何处理 ②数据年份:不同表格不一致,很多表格比如上市公司绿色专利申请与获得都是从1991年开始的,目前除了引用里的被引用信息更新到23年11月底,其余均更新到23年底 ③数据内容:两个表格 数据清单: 各省市绿色专利申请与获得(内部是地级市) 各省市绿色专利申请情况 各省市绿色专利获得情况

    毕业设计-基于Java+SpringBoot的校园互助系统微信小程序源码+数据库.zip文件

    毕业设计-基于Java+SpringBoot的校园互助系统微信小程序源码+数据库.zip文件 该项目是个人项目源码,项目中的源码都是经过本地编译过可运行的,都经过严格调试,确保可以运行!!!评审分达到95分以上。资源项目的难度比较适中,内容都是经过助教老师审定过的能够满足学习、使用需求,如果有需要的话可以放心下载使用。 该项目是个人项目源码,项目中的源码都是经过本地编译过可运行的,都经过严格调试,确保可以运行!!!评审分达到95分以上。资源项目的难度比较适中,内容都是经过助教老师审定过的能够满足学习、使用需求,如果有需要的话可以放心下载使用。 基于微信小程序的校园互助系统源码+数据库.zip文件 该项目是个人项目源码,项目中的源码都是经过本地编译过可运行的,都经过严格调试,确保可以运行!!!评审分达到95分以上。资源项目的难度比较适中,内容都是经过助教老师审定过的能够满足学习、使用需求,如果有需要的话可以放心下载使用。 基于微信小程序的校园互助系统源码+数据库.zip文件 该项目是个人项目源码,项目中的源码都是经过本地编译过可运行的,都经过严格调试,确保可以运

    springboot128中小企业人事管理系统代码.zip

    springboot128中小企业人事管理系统代码,含有完整的源码和报告文档

    社团管理-JAVA-基于springBoot的社团管理系统的设计与实现(毕业论文+PPT)

    管理员功能 用户管理 管理各类用户(社团负责人、会员)的注册、审核、修改和删除。 设置不同角色的权限,确保系统安全性。 社团管理 创建、编辑和删除社团信息,包括社团名称、简介、活动类型等。 审核新申请的社团,并管理社团的状态(正常、暂停、注销)。 活动管理 发布、编辑和删除社团活动信息,包含活动主题、时间、地点和参与人数。 查看活动报名情况和参与者列表。 财务管理 管理社团资金,包括收支记录、预算编制和财务报表生成。 支持费用报销流程,审核并记录社团开支。 数据统计与报告 生成各类统计报告,如社团活动参与情况、会员增长趋势等。 分析社团运营状况,为决策提供数据支持。 社团负责人功能 社团管理 查看和编辑社团基本信息及介绍,更新社团动态。 管理社团内的成员,包括添加、移除和调整角色。 活动策划 创建新活动,设置活动细节(时间、地点、内容、报名方式)。 发布活动通知,通过系统推送给社团成员。 报名管理 查看活动报名情况,管理参与人员名单。 发送活动提醒与通知,确保会员及时了解活动信息。 沟通交流 使用内部消息系统与社团成员进行沟通,发布公告和通知。 建立论坛或讨论区,促进

Global site tag (gtag.js) - Google Analytics