zoukankan      html  css  js  c++  java
  • plsql function



    do language plpgsql
    $$
    declare
     dz driver_zone%rowtype;
     leadtime integer;
    begin
        leadtime = 0;
        for dz in select * from driver_zone
        loop
            leadtime = leadtime + 1;
            update driver_zone set lead_time = leadtime where id = dz.id;
        end loop;
    end
    $$
    ;

    ===============================================

    CREATE OR REPLACE FUNCTION deliver_orders()
      RETURNS integer AS
    $BODY$
    DECLARE
      cnt integer := 0;
      rev consolidated_order_revenue%rowtype;
      firstOrder _order%rowtype;
      sellingCount integer := 0;
      buyingCount integer := 0;
    BEGIN
        FOR rev IN select distinct * from consolidated_order_revenue where id in (select buying_consolidation_id from _order where created_on > '2013-11-01')
        LOOP
    SELECT * INTO firstOrder FROM _order WHERE buying_consolidation_id = rev.id;

    SELECT COUNT(*) INTO buyingCount FROM _order WHERE buying_consolidation_id = firstOrder.buying_consolidation_id;
    SELECT COUNT(*) INTO sellingCount FROM _order WHERE selling_consolidation_id = firstOrder.selling_consolidation_id;

    IF sellingCount > 0 AND buyingCount <> sellingCount THEN
    RAISE NOTICE 'Fixing revenue: % (buying %, selling %)', rev.id, buyingCount, sellingCount;
    END IF;

        END LOOP;
        
        RAISE NOTICE 'Delivered % orders', cnt;
        RETURN cnt;
    END;
    $BODY$
      LANGUAGE plpgsql VOLATILE
      COST 100;
    ALTER FUNCTION deliver_orders()
      OWNER TO jetty;

  • 相关阅读:
    java第一次作业
    第十一次作业
    第十次作业
    第九次作业
    第八次作业
    第七次作业
    第六次作业
    第五次作业
    实验四,实验五
    Java_实验二
  • 原文地址:https://www.cnblogs.com/Uncho/p/4949002.html
Copyright © 2011-2022 走看看