广

oracle数据库

  • MYSQL
  • MSSQL
  • Redis
  • MongoDB
  • oracle数据库
  • 数据管理

    ORACLE 截断字符串

    2018-04-09 07:41:06 次阅读 稿源:互联网
    广告
    全网推广平台,软文发布

    create or replace procedure ModifyLadingItemPack
    (
      ASoditemguid varchar2,                  --合同电子仓单明细GUID
      ALadingitemGUID varchar2,               --提单子项GUID
      ACDResID varchar2,                      --电子仓单号
      APackageIDList varchar2,                --仓单捆包具体GUID列表
      Aladingnum float,
      Aladingpieces float,
      AReturnValue out integer                --返回值:
    )
    is
      ALadingItem_PackagesGUID varchar(32);
      ATempIDList varchar2(4000);
      AID varchar2(32);
      APackageWeight float;
      APackagePiece float;
      ATotalPackWeight float;
    begin
      AReturnValue := 1;
      ATempIDList := APackageIDList;
      APackageWeight :=0;
      APackagePiece :=0;    ---------------------------------更新合同电子仓单明细---------------------------
      while ( INSTR(ATempIDList,':' ) > 0 ) or ( LENGTH(ATempIDList ) > 0 ) loop
            if INSTR(ATempIDList,':' ) > 0 then            select sys_guid() into ALadingItem_PackagesGUID from dual;
               AID := SUBSTR(ATempIDList ,1,INSTR( ATempIDList,':') - 1 );
               ATempIDList := SUBSTR(ATempIDList,INSTR( ATempIDList,':') + 1 , LENGTH(ATempIDList) - INSTR(ATempIDList,':'));            ---------------------------------提单捆包明细----------------------------------
               insert into HT_LadingItem_packages(sGUID, sLadingItemGUID, sCDResID, sPackageID)
              values(ALadingItem_PackagesGUID, ALadingitemGUID, ACDResID,AID);            ---------------------------------更新仓单捆包明细状态---------------------------
               UPDATE ZY_Packages SET state = 5 WHERE SGUID = AID;            select fWeight into ATotalPackWeight from ZY_Packages where sGUID=AID;            APackageWeight:=APackageWeight+ATotalPackWeight;
               APackagePiece:=APackagePiece+1;
            else
               AID := ATempIDList;
               ATempIDList := '';
            end if;
       end loop;    update HT_SODItem set fLadingNum=fLadingNum+APackageWeight,fLadingPieces=fLadingPieces+APackagePiece
       where sGUID=ASoditemguid;   COMMIT;
    EXCEPTION
      WHEN OTHERS THEN BEGIN
        AReturnValue := 99;
        ROLLBACK;
      END;
    end;

    一起学吧部分文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与一起学吧进行文章共享合作。

    广告
    广告
    广告
    广告