日期:2014-05-17  浏览次数:20949 次

oracle 游标统计
下面的sql代码是我用游标进行统计的oracle 语句,本来这个是sql 用统计的,现在换库了,需要改成oracle的,我对oracle不熟,里面改的语法都是网上一边找资料一边改的,现在还有一些问题,小弟找不到原因。请各位大侠帮帮忙看看。
这个东西很急,在线等。
SQL code


 CREATE  GLOBAL   TEMPORARY   TABLE  Temp_Table
  (
    ITEM_CLASS    varchar2(100),
    QUANTITY      NUMBER,   ----
    COSTS         NUMBER,
    UNITS_CODE    varchar2(100),
    INP_NO        varchar2(100),
    ITEM_NO       NUMBER ,
    ITEM_CODE     varchar2(100),
    ITEM_NAME     varchar2(100),
    GENERAL_NAME  varchar2(100),
    ITEM_SPEC     varchar2(100),
    UNITS         varchar2(100),
    AMOUNT        NUMBER,
    UNIT_PRICE    NUMBER,
    CHARGES       NUMBER,
    CLASS_ON_INP_RCPT varchar2(100),
    DRUG_SIGN     varchar2(100),
    BILLING_DATE_TIME date,
    INSURANCE_CODE varchar2(100),
    INSURANCE_PAY  NUMBER,
    PERSON_STATUS  varchar2(100),
    CHARGE_TYPE    varchar2(100),
    PAY_IN         NUMBER,  
    PAY_OUT        NUMBER  
)
ON COMMIT DELETE ROWS;

declare  temp_column varchar2;
  
CURSOR order_cursor_1 IS select distinct ITEM_CLASS from V_CONN_INP_BILL_DETAIL; --定义游标
begin
open order_cursor_1 --打开游标
LOOP
 FETCH order_cursor_1 INTO temp_column; 
 EXIT WHEN order_cursor_1%NOTFOUND;
--FETCH NEXT FROM order_cursor_1 INTO @temp_column
--WHILE @@FETCH_STATUS = 0 
  --begin
    insert into Temp_Table select B.ITEM_CLASS,B.QUANTITY,B.COSTS,B.UNITS_CODE,B.INP_NO,B.ITEM_NO,B.ITEM_CODE,B.ITEM_NAME,B.GENERAL_NAME,B.ITEM_SPEC,B.UNITS
,B.AMOUNT,B.UNIT_PRICE,B.CHARGES,B.CLASS_ON_INP_RCPT,B.DRUG_SIGN,B.BILLING_DATE_TIME,B.INSURANCE_CODE
,B.INSURANCE_PAY,P.CHARGE_TYPE,P.PERSON_STATUS,
--下面根据条件判断
(CASE P.CHARGE_TYPE 
      WHEN '01' THEN 0 
      ELSE 
      CASE 
        WHEN (p.PERSON_STATUS='06') THEN  CHARGES 
        WHEN (p.PERSON_STATUS='07') THEN  CHARGES 
        WHEN (p.PERSON_STATUS='08') THEN  CHARGES 
        WHEN (p.PERSON_STATUS='09') THEN  CHARGES 
      ELSE
        B.INSURANCE_PAY * B.CHARGES  
      END          
      END)  AS PAY_IN,
(CASE P.CHARGE_TYPE 
      WHEN '01' THEN   CHARGES   
      ELSE 
      CASE 
        WHEN (p.PERSON_STATUS='06') THEN 0
        WHEN (p.PERSON_STATUS='07') THEN 0
        WHEN (p.PERSON_STATUS='08') THEN 0
        WHEN (p.PERSON_STATUS='09') THEN 0
      ELSE
      (1 - B.INSURANCE_PAY) * B.CHARGES
      END
      END)  AS PAY_OUT

--B.INSURANCE_PAY * B.CHARGES as PAY_IN,(1 - B.INSURANCE_PAY) * B.CHARGES as PAY_OUT
  from V_CONN_INP_BILL_DETAIL B,V_CONN_INP_PATS_VISIT P where B.ITEM_CLASS = temp_column AND B.INP_NO=P.SCOPE  --SCOPE是住院号
  
  
        insert into Temp_Table select'小计',0,0,'','',0,'','','','',''
,0,0,0,'','','','',0,'',''
,SUM(CASE P.CHARGE_TYPE 
      WHEN '01' THEN 0 
      ELSE 
      CASE 
        WHEN (p.PERSON_STATUS='06') THEN CHARGES 
        WHEN (p.PERSON_STATUS='07') THEN  CHARGES 
        WHEN (p.PERSON_STATUS='08') THEN  CHARGES 
        WHEN (p.PERSON_STATUS='09') THEN  CHARGES 
      ELSE
        B.INSURANCE_PAY * B.CHARGES  
      END          
      END),
SUM(CASE P.CHARGE_TYPE 
      WHEN '01' THEN  CHARGES   
      ELSE 
      CASE 
        WHEN (p.PERSON_STATUS='06') THEN 0
        WHEN (p.PERSON_STATUS='07') THEN 0
        WHEN (p.PERSON_STATUS='08') THEN 0
        WHEN (p.PERSON_STATUS='09') THEN 0
      ELSE
      (1 - B.INSURANCE_PAY) * B.CHARGES
      END
      END)
        from V_CONN_INP_BILL_DETAIL B,V_CONN_INP_PATS_VISIT P 
         where ITEM_CLASS = temp_column  AND B.INP_NO=P.SCOPE  --这里就拼小计需要统计的列了,注意列要和上面的一样
         
   -- FETCH NEXT FROM order_cursor_1 INTO @temp_column --让游标读取下一个
  --end
  END LOOP; 
close order_cursor_1 --关闭游标  
end;


insert into Temp_Table select '合计',0,0,'','',0,'','','','',''
,0,0,0,'','','','',0,'',''
,SUM(CASE P.CHARGE_TYPE 
      WHEN '01' THEN 0 
      ELSE 
      CASE 
        WHEN (p.PERSON_STATUS='06') THEN  CHARGES 
        WHEN (p.PERSON_STATUS='07') THEN  CHARGES 
        WHEN (p.PERSON_S