`
z_kanhai
  • 浏览: 52147 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

函数的使用

 
阅读更多
create or replace function Fun_getinvclPK( cinvclasscode varchar2,cinvclasslev number)
  return varchar2 is
   fpk_invcl varchar(200) := '';
   invclass_code varchar(20):='';
   invclass_lev number :=0;
begin

   invclass_code := trim(cinvclasscode);
   invclass_code := substr(invclass_code,0,length(invclass_code)-2);
   invclass_lev := cinvclasslev-1;
   select pk_invcl into fpk_invcl from bd_invcl where invclasscode like invclass_code||'%' and invclasslev = invclass_lev;


  return fpk_invcl;
end;



create or replace function Fun_getinvclInfo( cinvclasscode varchar2,cinvclasslev number)
  return varchar2 is
   fpk_invcl varchar(200) := '';
   invclass_code varchar(20):='';
   invclass_lev number :=0;
begin

   invclass_code := trim(cinvclasscode);
   invclass_code := substr(invclass_code,0,length(invclass_code)-2);
   invclass_lev := cinvclasslev-1;
   select pk_invcl into fpk_invcl from bd_invcl where invclasscode like invclass_code||'%' and invclasslev = invclass_lev;
  
  select invclasscode into xx   from bd_invcl  where bd_invcl.pk_invcl = fpk_invcl;

  return fpk_invcl;
end;




create or replace function f1(pk bd_corp.pk_corp%type) return bd_corp.unitcode%type
as
v_unitcode bd_corp.unitcode%type;
begin
    select unitcode into v_unitcode from bd_corp where pk_corp=pk;
    return v_unitcode;
end;



create or replace function Fun_getRInfo( cpkcorp varchar2,cflag number,cpk varchar2)
  return varchar2 is
   rinfo varchar(200) := '';
   pkcorp varchar(20):='';
   pk varchar(20):='';
   flag number :=0;
begin

   pkcorp := trim(cpkcorp);
   flag := cflag;
   pk := cpk;
   --公司
   if (flag = 0) then
      select unitcode into rinfo from bd_corp where pk_corp=pkcorp and nvl(dr,0)=0;
   end if;
   if (flag = 1) then
      select unitname  into rinfo from bd_corp where pk_corp=pkcorp and nvl(dr,0)=0;
   end if;
   --商品分类
    if (flag = 3) then
      select invclasscode  into rinfo from bd_invcl where pk_corp=pkcorp and nvl(dr,0)=0 and pk_invcl = pk;
   end if;
 
  
  
  return rinfo;
end;

select Fun_getRInfo('1114',5,'') aa ,Fun_getRInfo('1004',1,'') bb from dual;



select * from bd_invcl





create or replace function Fun_getRInfo( cpkcorp varchar2,cflag number,cpk varchar2)
  return varchar2 is
   rinfo varchar(200) := '';
   pkcorp varchar(20):='';
   pk varchar(20):='';
   flag number :=0;
begin

   pkcorp := trim(cpkcorp);
   flag := cflag;
   pk := cpk;
   --公司编码
   if (flag = 0) then
      if (pkcorp=='0001') then
      unitcode='0001'
      else
      select unitcode into rinfo from bd_corp where pk_corp=pkcorp and nvl(dr,0)=0;
      end if;
     
   end if;
   --公司名称
   if (flag = 1) then
       if (pkcorp=='0001') then
       unitcode='0001'
       else
       select unitname  into rinfo from bd_corp where pk_corp=pkcorp and nvl(dr,0)=0;
       end if;
    
   end if;
   --商品分类编码
    if (flag = 2) then
      select invclasscode  into rinfo from bd_invcl where  nvl(dr,0)=0 and pk_invcl = pk;
   end if;
 
      --商品分类名称
    if (flag = 3) then
      select invclassname  into rinfo from bd_invcl where  nvl(dr,0)=0 and pk_invcl = pk;
   end if;
  
    --主计量单位编码
    if (flag = 4) then
      select shortname  into rinfo from bd_measdoc where  nvl(dr,0)=0 and pk_measdoc = pk;
   end if;
  
     --主计量单位名称
    if (flag = 5) then
      select measname  into rinfo from bd_measdoc where  nvl(dr,0)=0 and pk_measdoc = pk;
   end if;
  
      --自定义项档案列表名称
    if (flag = 6) then
      select doclistname  into rinfo from bd_defdoclist where nvl(dr,0)=0 and pk_defdoclist = pk;
   end if;
  
      --自定义项档案列表编码
    if (flag = 7) then
      select doclistcode  into rinfo from bd_defdoclist where  nvl(dr,0)=0 and pk_defdoclist = pk;
   end if;
  
      --基础数据资源表名称
    if (flag = 6) then
      select bdname   into rinfo from bd_bdinfo where nvl(dr,0)=0 and pk_bdinfo= pk;
   end if;
  
      --基础数据资源表编码
    if (flag = 7) then
      select bdcode  into rinfo from bd_bdinfo where  nvl(dr,0)=0 and pk_bdinfo= pk;
   end if;
  
  return rinfo;
end;

--商品税率
create or replace function Fun_gettptaxiInfo(ctypetaxitempk varchar2,cinvclpk varchar2,cflag number)
return varchar2 is typettinfo varchar(200) :='';
cfpk varchar2(20):='';
cinvpk varchar2(20):='';
flag number :=0;
begin
cfpk:=ctypetaxitempk;
cinvpk:=cinvclpk;
flag:=cflag;
if(flag=0) then
select unitcode into  typettinfo from bd_corp where pk_corp=(select pk_corp from zm_typetaxitem_h where pk_typetaxitem_h=cfpk and nvl(dr,0)=0) and nvl(dr,0)=0;
end if;
if(flag=1) then
select unitname into  typettinfo from bd_corp where pk_corp=(select pk_corp from zm_typetaxitem_h where pk_typetaxitem_h=cfpk and nvl(dr,0)=0) and nvl(dr,0)=0;
end if;
if(flag=2) then
select invclasscode into  typettinfo from bd_invcl where pk_invcl=cinvpk and nvl(dr,0)=0;
end if;
if(flag=3) then
select invclassname into  typettinfo from bd_invcl where pk_invcl=cinvpk and nvl(dr,0)=0;
end if;
return typettinfo ;
end;

--获取上级商品分类编码及名称
create or replace function Fun_getinvclInfo( cinvclasscode varchar2,cinvclasslev number,cflag number)
  return varchar2 is
   finvclinfo varchar(200) := '';
   invclass_code varchar(20):='';
   invclass_lev number :=0;
   flag number :=0;
begin
   invclass_code := trim(cinvclasscode);
   invclass_code := substr(invclass_code,0,length(invclass_code)-2);
   invclass_lev := cinvclasslev-1;
   if(flag=0) then
   select invclassname into finvclinfo from bd_invcl where invclasscode like invclass_code||'%' and invclasslev = invclass_lev;
   else
   finvclinfo:=invclass_code;
    end if;
 
  return finvclinfo;
end;

Fun_getRInfo(a.pk_corp, 0, '') as unitcode,Fun_getRInfo(a.pk_corp, 1, '') as unitname,Fun_getinvclInfo(a.invclasscode,a.invclasslev,0) as fatherinvclassname, Fun_getinvclInfo(a.invclasscode,a.invclasslev,1) as fatherinvclass_code

create or replace function Fun_getinvclInfo( cinvclasscode varchar2,cinvclasslev number,cflag number)
  return varchar2 is
   finvclinfo varchar(200) := '';
   invclass_code varchar(20):='';
   invclass_lev number :=0;
   flag number :=0;
begin
   invclass_code := trim(cinvclasscode);
   invclass_code := substr(invclass_code,0,length(invclass_code)-2);
   invclass_lev := cinvclasslev-1;
   if(flag=0) then
   select invclassname into finvclinfo from bd_invcl where invclasscode like invclass_code||'%' and invclasslev = invclass_lev;
   end if
   if(flag=1) then
   finvclinfo:=invclass_code;
   end if;

  return finvclinfo;
end;

create or replace function Fun_getRInfo( cpkcorp varchar2,cflag number,cpk varchar2)
  return varchar2 is
   rinfo varchar(200) := '';
   pkcorp varchar(20):='';
   pk varchar(20):='';
   flag number :=0;
begin

   pkcorp := trim(cpkcorp);
   flag := cflag;
   pk := cpk;
   --公司编码
   if (flag = 0) then
      if (pkcorp='0001') then
      rinfo :='0001';
      else
      select unitcode into rinfo from bd_corp where pk_corp=pkcorp and nvl(dr,0)=0;
      end if;

   end if;
   --公司名称
   if (flag = 1) then
       if (pkcorp='0001') then
       rinfo :='0001';
       else
       select unitname  into rinfo from bd_corp where pk_corp=pkcorp and nvl(dr,0)=0;
       end if;

   end if;
   --商品分类编码
    if (flag = 2) then
      select invclasscode  into rinfo from bd_invcl where  nvl(dr,0)=0 and pk_invcl = pk;
   end if;

      --商品分类名称
    if (flag = 3) then
      select invclassname  into rinfo from bd_invcl where  nvl(dr,0)=0 and pk_invcl = pk;
   end if;

    --主计量单位编码
    if (flag = 4) then
      select shortname  into rinfo from bd_measdoc where  nvl(dr,0)=0 and pk_measdoc = pk;
   end if;

     --主计量单位名称
    if (flag = 5) then
      select measname  into rinfo from bd_measdoc where  nvl(dr,0)=0 and pk_measdoc = pk;
   end if;

      --自定义项档案列表名称
    if (flag = 6) then
      select doclistname  into rinfo from bd_defdoclist where nvl(dr,0)=0 and pk_defdoclist = pk;
   end if;

      --自定义项档案列表编码
    if (flag = 7) then
      select doclistcode  into rinfo from bd_defdoclist where  nvl(dr,0)=0 and pk_defdoclist = pk;
   end if;

     --父级自定义项档案表名称
    if (flag = then
      select docname  into rinfo from bd_defdoc where nvl(dr,0)=0 and pk_defdoclist = pk;
   end if;

      --父级自定义项档案表编码
    if (flag = 9) then
      select doccode  into rinfo from bd_defdoc where  nvl(dr,0)=0 and pk_defdoclist = pk;
   end if; 
   
      --基础数据资源表名称
    if (flag = 10) then
      select bdname   into rinfo from bd_bdinfo where nvl(dr,0)=0 and pk_bdinfo= pk;
   end if;
  
      --基础数据资源表编码
    if (flag = 11) then
      select bdcode  into rinfo from bd_bdinfo where  nvl(dr,0)=0 and pk_bdinfo= pk;
   end if;
  
    --产品线档案名称
    if (flag = 12) then
      select prodlinename   into rinfo from bd_prodline where nvl(dr,0)=0 and pk_prodline= pk;
   end if;
  
      --产品线档案编码
    if (flag = 13) then
      select prodlinecode  into rinfo from bd_prodline where  nvl(dr,0)=0 and pk_prodline= pk;
   end if;

   --税目税率名称
    if (flag = 14) then
      select taxname   into rinfo from bd_taxitems where nvl(dr,0)=0 and pk_taxitems= pk;
   end if;
  
      --税目税率编码
    if (flag = 15) then
      select taxcode   into rinfo from bd_taxitems where  nvl(dr,0)=0 and pk_taxitems= pk;
   end if;

  return rinfo;
end;
分享到:
评论

相关推荐

    Linux C函数库参考手册完整版 含Linux C函数使用手册chm 中文pdf格式

    Linux C函数库参考手册是一套Linux C函数使用手册,这里还提供了LinuxC函数手册chm,帮助大家查找。在Linux下,使用到的C语言函数中文手册,全都有实例,如果你是大神,完全不需要,如果你对英文的手册感到头疼,...

    vb api 函数使用手册

    《VB API函数使用手册》是一本详尽的资源,专为使用Visual Basic (VB)进行编程的开发者设计,涵盖了API函数的广泛应用。API(Application Programming Interface)函数是操作系统为应用程序提供的一种接口,允许...

    VB-API函数使用手册

    《VB-API函数使用手册》是一本专为VBA(Visual Basic for Applications)开发者设计的实用指南,涵盖了在VBA编程中使用API(Application Programming Interface)函数的广泛知识。API函数是Windows操作系统提供的一...

    HAL库+CubeMX+Stm32F405 实现串口定长收发、printf函数使用、自定义打印函数

    HAL库+CubeMX+Stm32F405 实现串口定长收发、printf函数使用、自定义打印函数 详情请看:https://lindoglog.blog.csdn.net/article/details/107463926

    excel 函数使用 计算方法

    ### Excel函数使用与计算方法详解 #### 一、函数与公式的概念 ##### 什么是函数? 在Excel中,函数是一种预定义的公式,用于执行特定的计算任务。它使用一个或多个参数作为输入,并返回一个结果。这些参数可以是...

    LIN bus_API 函数使用说明

    详细介绍了LIN的API函数的使用,包括代码的详细解读。

    JAVA函数使用手册

    这份“JAVA函数使用手册”可能是针对Java编程中的函数使用方法、设计原则以及常见问题的详细指南。以下是关于Java函数的一些关键知识点: 1. **函数定义与调用**:在Java中,函数通过`public void functionName参数...

    C语言函数使用.zip

    下面,我们将深入探讨C语言中的函数使用。 一、函数定义与声明 1. 函数定义:函数定义包括函数头(返回类型和函数名)和函数体。例如: ```c int add(int a, int b) { return a + b; } ``` 在这个例子中,`add`...

    Turbo C 函数使用方法

    Turbo C 是一款经典的C语言编译器,...了解并熟练运用这些基本的函数使用方法,将有助于你在 Turbo C 中编写更高效、更具结构化的程序。不断实践和探索,你将逐渐掌握C语言的精髓,并为更高级的编程技能打下坚实基础。

    常用EXCEL函数使用详解ppt课件.ppt

    Excel函数使用详解 Excel函数是Excel软件中的一种强大工具,通过使用函数,可以快速实现复杂的数据处理和分析。Excel函数有很多种类,包括财务函数、日期函数、时间函数、数学与三角函数、统计函数、数据库管理函数...

    socket_recv函数使用心得.

    socket_recv 函数使用心得 在学习 socket_recv 函数时,需要了解其返回值的含义和使用场景。在阻塞模式下,当网络异常时,recv 函数返回值为-1,表示连接异常,需要关闭连接。在非阻塞模式下,如果没有数据,recv ...

    Oracle分析函数使用总结

    Oracle分析函数使用总结Oracle分析函数使用总结Oracle分析函数使用总结Oracle分析函数使用总结

    串口屏LUA例程-绘图API函数使用说明V1.0.pdf

    在本文档中,我们主要将介绍大彩LUA脚本API函数中的绘图API函数使用方法,以及使用函数的注意事项。首先,让我们来了解一下LUA语言版本,当前文档支持的LUA版本为V5.5。接下来,我们将详细讲解如何使用绘图API函数,...

    Excel 中的 COUNTA 和 COUNTIF 函数使用入门.docx

    Excel 中的 COUNTA 和 COUNTIF 函数使用入门 Excel 中的 COUNTA 和 COUNTIF 函数是两种非常有用的函数,可以帮助用户快速统计单元格中的非空白单元格数量或特定值的出现次数。在本文中,我们将详细介绍 COUNTA 和 ...

    SYBASE iq与ORACLE使用分析函数计算同期值及常用计算函数使用

    "SYBASE iq与ORACLE使用分析函数计算同期值及常用计算函数使用" 本资源摘要信息主要介绍了SYBASE iq和ORACLE中使用分析函数计算同期值和常用计算函数的使用方法。文章涵盖了同期值的计算、累计及同期累计值的计算、...

    winAPI函数 使用手册

    《winAPI函数使用手册》是一本专为程序员设计的实用参考书籍,主要涵盖了Windows操作系统中的所有API函数。这本书对于想要深入了解系统级编程、提高编程技能的开发者来说,是一份不可多得的资源。Windows API...

    random函数使用详细讲解

    该文档是关于random函数使用详细讲解,主要在代码编写产生随机数的时候用到,详细介绍了random函数的各种用法,赶快下载看看吧~

    LinuxC函数库参考手册完整版含LinuxC函数使用手册chm中文pdf格式最新版本

    该手册不仅提供了详尽的Linux C函数使用指南,还特别提供了CHM格式的手册,以便于用户快速检索所需信息。 对于那些对英文技术文档感到困惑的初学者来说,本手册的中文实例将极大地降低学习难度,提高学习效率。即便...

    Excel中的SumIF函数使用

    Excel中的SumIF函数使用,Excel中的SumIF函数使用

    EXCEL函数使用及实例截图.ppt

    Excel 函数使用指南 Excel 函数是 Microsoft Excel 中的一个强大功能,可以帮助用户快速地进行数据计算和分析。Excel 函数有多种类型,包括数学函数、日期函数、时间函数、统计函数、数据库管理函数、文本函数、...

Global site tag (gtag.js) - Google Analytics