0

次のような状況があります。

「UNION ALL」で結合された6つの選択で構成されるスクリプトがあります。

CLP DB2 コンソールから、このスクリプトは失敗します。興味深いことに、各クエリは独立して機能し、ペアでグループ化すると機能します。しかし、3 つ以上で試してみると、失敗します。

だから、私の質問は次のとおりです。UNION ALLを1つ以上使用することに制限はありますか?

私の環境は次のとおりです。

  • クライアント。DB2 コネクト サーバー 10.1
  • zOS 390 (その側の DB2 バージョンは不明)
  • AIX 7.1

クエリは次のようになります (ただし、3 回)

SELECT
        ,'GG'
    ,varchar(right( '000000000000000' || rtrim(ltrim(eeee.zzzz)), 15), 15)  
        ,substr(char(right('**********'||char(left(replace(eeee.yyyy,' ','*')||'**********',10),10),10),10),1,7)
        ,eeee.kkkkk
        ,eeee.hhhhhh
            ,CASE WHEN hhhhhh='A5 ' THEN 'ARS' WHEN hhhhhh='A6 ' THEN 'AUD' WHEN hhhhhh='B5 ' THEN 'BRL' WHEN hhhhhh='U1 ' THEN 'GBP' WHEN hhhhhh='B9 ' THEN 'BND' WHEN hhhhhh='B6 ' THEN 'BNG' WHEN hhhhhh='C1 ' THEN 'CAD' WHEN hhhhhh='C3 ' THEN 'CLP' WHEN hhhhhh='C4 ' THEN 'CNY' WHEN hhhhhh='C5 ' THEN 'COP' WHEN hhhhhh='C7 ' THEN 'CRC' WHEN hhhhhh='L5 ' THEN 'HRK' WHEN hhhhhh='C9 ' THEN 'CYP' WHEN hhhhhh='X0 ' THEN 'CZK' WHEN hhhhhh='D0 ' THEN 'DKK' WHEN hhhhhh='D1 ' THEN 'DOP' WHEN hhhhhh='U0 ' THEN 'EGP' WHEN hhhhhh='E3 ' THEN 'EUR' WHEN hhhhhh='G5 ' THEN 'GTQ' WHEN hhhhhh='H0 ' THEN 'HTG' WHEN hhhhhh='H3 ' THEN 'HUF' WHEN hhhhhh='I1 ' THEN 'INR' WHEN hhhhhh='I2 ' THEN 'IDR' WHEN hhhhhh='K2 ' THEN 'WON' WHEN hhhhhh='L6 ' THEN 'LVL' WHEN hhhhhh='L7 ' THEN 'LTL' WHEN hhhhhh='M2 ' THEN 'MYR' WHEN hhhhhh='M6 ' THEN 'MXN' WHEN hhhhhh='I8 ' THEN 'ILS' WHEN hhhhhh='N2 ' THEN 'NZD' WHEN hhhhhh='N4 ' THEN 'NIO' WHEN hhhhhh='N6 ' THEN 'NOK' WHEN hhhhhh='T4 ' THEN 'XPF' WHEN hhhhhh='P0 ' THEN 'PKR' WHEN hhhhhh='P1 ' THEN 'PAB' WHEN hhhhhh='P3 ' THEN 'PEN' WHEN hhhhhh='P4 ' THEN 'PHP' WHEN hhhhhh='P5 ' THEN 'PLN' WHEN hhhhhh='R2 ' THEN 'RON' WHEN hhhhhh='U3 ' THEN 'RUB' WHEN hhhhhh='S0 ' THEN 'SAR' WHEN hhhhhh='R6 ' THEN 'RSD' WHEN hhhhhh='S2 ' THEN 'SGD' WHEN hhhhhh='K5 ' THEN 'SKK' WHEN hhhhhh='S4 ' THEN 'ZAR' WHEN hhhhhh='C2 ' THEN 'LKR' WHEN hhhhhh='S8 ' THEN 'SEK' WHEN hhhhhh='S9 ' THEN 'CHF' WHEN hhhhhh='T2 ' THEN 'THB' WHEN hhhhhh='T6 ' THEN 'TRL' WHEN hhhhhh='U4 ' THEN 'USD' WHEN hhhhhh='U6 ' THEN 'UAH' WHEN hhhhhh='U5 ' THEN 'AED' WHEN hhhhhh='U2 ' THEN 'UYU' WHEN hhhhhh='V0 ' THEN 'VEB' WHEN hhhhhh='V1 ' THEN 'VND' WHEN hhhhhh='J1 ' THEN 'JPY' ELSE '###' END
        ,  case when eeee.FCRCIDF='Y' then 1 else 0 end
        ,
                    CASE
                    WHEN SUBSTR(eeee.yyyy,7,1) = 'X' THEN 'X'       
                    WHEN SUBSTR(eeee.yyyy,4,2) = 'O' THEN 'O'       
                    WHEN SUBSTR(eeee.yyyy,4,2) = 'C' THEN 'C'       
                    WHEN SUBSTR(eeee.yyyy,4,2) = 'R' THEN 'R'       
                    WHEN eeee.lll = 'F' THEN 'F'            
                    WHEN eeee.ppp <> '' THEN 'D'            
                    WHEN eeee.rrr = 0 THEN '0'          
                    WHEN eeee.rrr <> eeee.ACINTOT THEN 'P'      
                    WHEN eeee.rrr = eeee.ACINTOT THEN '1'           
                    ELSE '*'                    
                    END
        ,1
        ,eeee.DCINISS
        ,0
        from  (SELECT ori.*,oric.tttt FROM www.SK1V01_CUSTOMER ori left OUTER JOIN www.SK1V01A_CUSTCUF oric
      ON ori.bbbb=oric.bbbb  and   ori.ICUSCNO=oric.ICUSCNO ) as aaaa
             ,www.SK1V02_OPENBILL eeee,www.SK1V41_OPENBILL kkkk
         where      aaaa.bbbb=eeee.bbbb
              and   aaaa.cagllic=eeee.cagllic
              and   aaaa.icuscno=eeee.icuscno
4

1 に答える 1

0

声明全体がなければ、正確な理由を特定するのはかなり困難です。たった 1 つの部分が非常に長く、書式設定が不十分であることを考えると、すべてを掘り下げる必要があるかどうかはわかりません。しかし、問題の解決に役立ついくつかのアプローチを提案できます。

最初に最も単純な部分。ほとんどすべてのコンピューター言語で、適切にフォーマットされたコードは、何が起こっているかの構造を理解するのに役立ちます。また、クエリ間の違いを見つけるのにも役立ちます。(おそらくこれを知っているでしょう。コードを投稿しようとしたときに、コードのフォーマットが失われただけです。)

複数の複雑なクエリを UNION しようとすると、クエリ間で列の不一致が発生することは珍しくありません。欠落している、または余分な列があるか、列が順不同である可能性があります。ただし、一部の列式が異なる型に評価される可能性があります。念のために、これらの式をキャストするか、型変換関数を使用することをお勧めします。

ここでは多くのことが起こっています。どの部分が問題の原因であるかがわかるまで、各主要なサブクエリで同じように、コードの大きなチャンクをコメントアウトするバージョンでテストしてみてください。

hhhhhh にとてつもなく長い CASE 式があります。これらの値のペアを、結合できるルックアップ テーブルに入れてみませんか。

大規模なプログラムを作成する場合と同様に、モジュール アプローチを使用してみてください。主要なクエリごとにビューを作成し、それらを一緒に UNION することができます。(一部の開発者は、モジュラー コードのレイヤーのようなビューのレイヤーを使用します)。

ビューに関するメタデータは、データベース カタログ ビューで利用できます。これは、ユニオン ビューのセット内の列の属性を比較するクエリを作成できることを意味します。

于 2015-07-11T16:28:12.833 に答える