| 网站首页 | 技术文章 | 下载频道 | 博客 | 编程论坛 |
 
| 技术教程首页 | 开发语言 | WEB开发 | .NET技术 | 数据库 | 操作系统 | 网页制作 |
 
 
您现在的位置: 编程中国 >> 技术教程 >> 数据库 >> Oracle >> 正文
  ►  自己做的存储过程,使用了指针,并调用了外部了时间参数!
自己做的存储过程,使用了指针,并调用了外部了时间参数!
作者:飙马    阅读人次:……    文章来源:本站原创    发布时间:2007/10/27    网友评论()条
 

原帖及讨论:http://bbs.bccn.net/thread-180948-1-1.html

*/ --------------------------------------------------------------------------------------
*/ 出自: 编程中国  http://www.bccn.net
*/ 作者: 飙马        
*/ 时间: 2007-10-26  编程论坛首发
*/ 声明: 尊重作者劳动,转载请保留本段文字
*/ --------------------------------------------------------------------------------------


因为涉及到工作的保密性,所以不能将全部代码发上来,请大家见谅!基本的功能是这样的:通过在程序中选择一个时间,根据这个时间来选择符合条件的数据,并将它插入某个表。插入的时候,要进行一个判断,如果这个记录已经存在了,就不插入,不存在的话就插入该数据,这个是用游标来实现的。



CURSOR acc_c IS    /* 定义游标,从表中选出记录 */
     select  ……
     from    ……
     where
     /*原语句  a.DATE=732949 */
     to_date(1721425+a.DATE,'J')= to_date(ParaTime,'YYYY-MM-DD') and/*  将时间参数赋给选择语句*/
     ……
      
  
    acc_r acc_c%ROWTYPE;                /* 变量acc_r与acc_c类型相同*/
    AmountToMove NUMBER;


BEGIN

  OPEN acc_c;
  LOOP
  
  FETCH acc_c INTO acc_r;
    EXIT WHEN acc_c%NOTFOUND;           /*记录不存在时退出*/
     begin
     insert into ……  /*记录存在时插入*/
     values ……
     EXCEPTION  
    when others  then null;
   end;  
    
   END LOOP ;
  commit;
   CLOSE acc_c ;   /*关闭指针*/
  

/*修改表*/  
update ……(
select …… from(
   select ……
    from ……
     where
      ……
     /*原语句   a.DATE=732949 */
      to_date(1721425+a.DATE,'J')= to_date(ParaTime,'YYYY-MM-DD') and/*将时间参数赋给选择语句*/
      …… where ……
where EndDate=to_date(ParaTime,'YYYY-MM-DD');
/*原语句  where to_number(to_char(EndDate,'J'))=732949+1721425;*/

commit;

    
END;


此主题相关图片如下:

 

 
文章录入:编辑01    责任编辑:编辑01 
  • 上一篇文章:

  • 下一篇文章: 没有了

  •  
    相关文章
    原创地带
    24小时热门帖子