zoukankan      html  css  js  c++  java
  • 检查所有资产的剩余折旧年限

    View Code
    DECLARE
       
    CURSOR c_asset IS
          
    SELECT fab.asset_id,
                 fab.asset_number,
                 fb.book_type_code
            
    FROM fa_additions_b fab,
                 fa_books       fb
           
    WHERE fab.asset_id = fb.asset_id
             
    AND fb.date_ineffective IS NULL
             
    AND fb.transaction_header_id_out IS NULL
             
    AND fb.period_counter_fully_retired IS NULL;

       l_prorate_date DATE;
       
    --l_book_type_code varchar2(20);
       --l_asset_id number;
       l_remaining_life_years  NUMBER;
       l_remaining_life_months 
    NUMBER;
       l_min_cpod              DATE;
       l_num_per_fiscal_year   
    NUMBER;
       dummy_num               
    NUMBER;
    BEGIN

       
    FOR i IN c_asset
       LOOP
       
          
    --get prorate date
          SELECT /*adjusted_recoverable_cost, */
           prorate_date
            
    INTO /*:Inquiry_books.adjusted_recoverable_cost, */
                 l_prorate_date
            
    FROM fa_books
           
    WHERE book_type_code = i.book_type_code
             
    AND asset_id = i.asset_id
             
    AND date_ineffective IS NULL;
       
          
    SELECT MIN(calendar_period_open_date)
            
    INTO l_min_cpod
            
    FROM fa_deprn_periods
           
    WHERE book_type_code = i.book_type_code;
       
          
    --get fiscal year
          SELECT number_per_fiscal_year
            
    INTO l_num_per_fiscal_year
            
    FROM fa_calendar_types
           
    WHERE calendar_type =
                 (
    SELECT decode(fab.conversion_date,
                                
    NULL,
                                fabc.deprn_calendar,
                                fabc.prorate_calendar)
                    
    FROM fa_book_controls fabc,
                         fa_books         fab
                   
    WHERE fabc.book_type_code = i.book_type_code
                     
    AND fab.asset_id = i.asset_id
                     
    AND fab.book_type_code = fabc.book_type_code
                     
    AND fab.transaction_header_id_out IS NULL);
       
          
    IF (l_num_per_fiscal_year = 12THEN
          
             
    IF l_prorate_date < l_min_cpod THEN
                
    SELECT decode(fab.conversion_date,
                              
    NULL,
                              fab.life_in_months 
    -
                              ((to_number(to_char(fcp1.end_date, 
    'YYYY')) * 12 +
                              fcp1.period_num) 
    -
                              (to_number(to_char(fcp2.end_date, 
    'YYYY')) * 12 +
                              fcp2.period_num)),
                              fab.life_in_months 
    -
                              ((to_number(to_char(fcp1.end_date, 
    'YYYY')) * 12 +
                              fcp1.period_num) 
    -
                              (to_number(to_char(fcp3.end_date, 
    'YYYY')) * 12 +
                              fcp3.period_num)))
                  
    INTO dummy_num
                  
    FROM fa_books            fab,
                       fa_calendar_periods fcp1, 
    -- open
                       fa_calendar_periods fcp2, -- prorate
                       fa_calendar_periods fcp3, -- deprn_start
                       fa_book_controls    fabc,
                       fa_deprn_periods    fdp
                 
    WHERE fab.asset_id = i.asset_id
                   
    AND fab.book_type_code = i.book_type_code
                   
    AND fab.transaction_header_id_out IS NULL
                   
    AND fabc.book_type_code = fab.book_type_code
                   
    AND fdp.period_counter =
                       (
    SELECT MAX(dp.period_counter)
                          
    FROM fa_deprn_periods dp
                         
    WHERE dp.book_type_code = i.book_type_code)
                   
    AND fdp.book_type_code = fab.book_type_code
                   
    AND fcp1.calendar_type =
                       decode(fab.conversion_date,
                              
    NULL,
                              fabc.prorate_calendar,
                              fabc.deprn_calendar)
                   
    AND fcp1.start_date = fdp.calendar_period_open_date
                   
    AND fcp2.calendar_type = fabc.prorate_calendar
                   
    AND fab.prorate_date BETWEEN fcp2.start_date AND
                       fcp2.end_date
                   
    AND fcp3.calendar_type = fabc.deprn_calendar
                   
    AND fab.deprn_start_date BETWEEN fcp3.start_date AND
                       fcp3.end_date;
             
             
    ELSE
             
                
    SELECT decode(fab.conversion_date,
                              
    NULL,
                              fab.life_in_months 
    -
                              (fdp1.period_counter 
    - fdp2.period_counter),
                              fab.life_in_months 
    -
                              (fdp1.period_counter 
    - fdp3.period_counter))
                  
    INTO dummy_num
                  
    FROM fa_books         fab,
                       fa_deprn_periods fdp1, 
    -- open
                       fa_deprn_periods fdp2, -- prorate
                       fa_deprn_periods fdp3 -- deprn_start
                 WHERE fab.asset_id = i.asset_id
                   
    AND fab.book_type_code = i.book_type_code
                   
    AND fab.transaction_header_id_out IS NULL
                   
    AND fab.book_type_code = fdp1.book_type_code
                   
    AND fdp1.period_counter =
                       (
    SELECT MAX(dp.period_counter)
                          
    FROM fa_deprn_periods dp
                         
    WHERE dp.book_type_code = i.book_type_code)
                   
    AND fab.book_type_code = fdp2.book_type_code
                   
    AND (fab.prorate_date BETWEEN fdp2.calendar_period_open_date AND
                       fdp2.calendar_period_close_date 
    OR
                       (fab.prorate_date 
    > fdp2.calendar_period_close_date AND
                       fdp2.period_close_date 
    IS NULL))
                   
    AND fab.book_type_code = fdp3.book_type_code
                   
    AND fab.deprn_start_date BETWEEN
                       fdp3.calendar_period_open_date 
    AND
                       fdp3.calendar_period_close_date;
             
    END IF;
          
          
    ELSE
          
             
    SELECT decode(fab.conversion_date,
                           
    NULL,
                           fab.life_in_months 
    -
                           
    floor(months_between(fdp.calendar_period_close_date,
                                                fab.prorate_date)),
                           fab.life_in_months 
    -
                           
    floor(months_between(fdp.calendar_period_close_date,
                                                fab.deprn_start_date)))
               
    INTO dummy_num
               
    FROM fa_books         fab,
                    fa_deprn_periods fdp
              
    WHERE fab.book_type_code = i.book_type_code
                
    AND fdp.book_type_code = i.book_type_code
                
    AND fab.asset_id = i.asset_id
                
    AND fab.date_ineffective IS NULL
                
    AND fdp.period_close_date IS NULL;
          
    END IF;
       
          
    IF (dummy_num < 1THEN
             l_remaining_life_years  :
    = 0;
             l_remaining_life_months :
    = 0;
             
    --output
             dbms_output.put_line(i.asset_number || '(' || i.book_type_code || '):' ||
                                  
    ' Remaining years:' ||
                                  l_remaining_life_years 
    ||
                                  
    ' Remaining months:' ||
                                  l_remaining_life_months);
          
    ELSE
             l_remaining_life_years  :
    = floor(dummy_num / 12);
             l_remaining_life_months :
    = MOD(dummy_num, 12);
             
    --output
             dbms_output.put_line(i.asset_number || '-' || i.book_type_code || ':' ||
                                  
    ' Remaining years:' ||
                                  l_remaining_life_years 
    ||
                                  
    ' Remaining months:' ||
                                  l_remaining_life_months);
          
    END IF;
       
       
    END LOOP;
    END;

             

                成长

           /      |     \

        学习   总结   分享

    QQ交流群:122230156

  • 相关阅读:
    08 linux文件检索和编辑
    Mybatis3详解(二十)——Mybatis中使用的9种设计模式(转)
    Mybatis3详解(十八)——Mybatis运行原理之Mapper接口的动态代理过程
    Mybatis3详解(十七)——Mybatis运行原理之SqlSession的构建过程
    Mybatis3详解(十六)——Mybatis运行原理之SqlSessionFactory的构建过程
    Mybatis3详解(十五)——Mybatis整合Spring框架
    Mybatis3详解(十四)——Mybatis的分页
    Mybatis3详解(十三)——Mybatis逆向工程
    Mybatis3详解(十二)——Mybatis缓存
    Mybatis3详解(十一)——延迟加载
  • 原文地址:https://www.cnblogs.com/benio/p/2077361.html
Copyright © 2011-2022 走看看