3

Oracle DBには、newitems、itemdetails、ticketitemsテーブルとして3つのテーブルがあります。次のようないくつかのダミーデータ:

チケットアイテム:

id    ticketid     itemid    quantity

1     100          9999      2
2     100          9998      5
3     100          2222      3

アイテムの詳細:

id    description    col_sumthing   extra_col
9999  Marlboro       val_sumthing   123_op
9998  Cigar Black    val_sumthing   456_pqwe

新しいアイテム:

id    description    col_sumthing
2222  100Pipes       val_different

最初は、itemdetails + ticketitemsからのみデータをフェッチする必要がありました。これは、単純な結合を使用すると非常に簡単でした。クエリは次のとおりです。

SELECT "TI".*, "I"."ID" AS "ITEMID", "I"."DESCRIPTION", "I"."col_sumthing" 
  FROM "TICKETITEMS" "TI"
 INNER JOIN "ITEMDETAILS" "I" ON TI.ITEMID = I.ID
 WHERE (TI.TICKET = '100')

そんな感じ。

これで、ticketitemsテーブルにいくつかのアイテムが存在する可能性のあるnewitemテーブルが導入されました。

だから私は次のような結果が欲しいです:

Final Result:
id    description    itemid    quantity   col_sumthing    extra_col
1     Marlboro       9999      2          val_sumthing    123_op
2     Cigar Black    9998      5          val_sumthing    456_pqwe
3     100Pipes       2222      3          val_different   

私が直面している問題は、itemdetailsに詳細が見つからない場合にのみNEWITEMSをチェックインする必要があるということです。その他の回避策も歓迎します。

4

3 に答える 3

2
SELECT TI.ID AS "id",
       COALESCE( I.DESCRIPTION, NI.DESCRIPTION ) AS "description"
       COALESCE( I.ID, NI.ID ) AS "itemid",
       TI.QUANTITY AS "quantity"
       COALESCE( I.COL_SUMTHING, NI.COL_SUMTHING ) AS "col_sumthing"
       I.EXTRA_COL AS "extra_col"
  FROM TICKETITEMS TI
  LEFT OUTER JOIN ITEMDETAILS I ON TI.ITEMID = I.ID
  LEFT OUTER JOIN NEWITEMS NI ON I.ID IS NULL AND TI.ITEMID = NI.ID
 WHERE TI.TICKETID = '100'
于 2012-06-29T15:06:40.683 に答える
0

2つのOUTER結合を使用できます。

SELECT ti.*, 
       nvl(i.id, n.id) itemid, 
       nvl(i.description, n.description) description, 
       nvl(i.col_sumthing, n.col_sumthing) col_sumthing 
  FROM ticketitems ti
  LEFT JOIN itemdetails i ON ti.itemid = i.id
  LEFT JOIN newsitems n ON ti.itemid = n.id
 WHERE ti.ticket = '100'

これは、両方の詳細テーブルがID主キーとして持っている限り機能します。COALESCE3つ以上の詳細テーブルがある場合に使用します。

于 2012-06-29T14:54:40.940 に答える
0

ITEMDETAILSテーブルとNEWITEMSテーブルのUNIONを操作する必要がありますが、データをランク付けして、関連する行のみを取得する必要があります。

select 
  ti.id, 
  it.description, 
  it.id as itemid, 
  ti.quantity, 
  it.col_sumthing, 
  it.extra_col
from 
  ticketitem ti
  join (
    select 
      id,  
      description,  
      col_sumthing,  
      extra_col,  
      row_number() over (partition by id order by item_ordering) as item_priority
    from (
      select id, description, col_sumthing, extra_col, 1 as item_ordering
      from itemdetails
      union all
      select id, description, col_sumthing, null as extra_col, 2 as item_ordering
      from newitems 
    )
  ) it on (it.id = ti.itemid and it.item_priority = 1)
于 2012-06-29T14:56:34.097 に答える