sql >> Databasteknik >  >> RDS >> Oracle

Är detta en möjlig Oracle-bugg eller har jag missat något?

Inte ett stort fan av AND/WHERE column = (SELECT column....) , holistiskt sett är det bättre att skriva AND/WHERE column IN (SELECT column...) . Men i ditt fall ser det inte ut som att det finns möjlighet till flera rader eller kolumner i underfrågan. Vad sägs om-

var comment_id number
exec :comment_id := 3052753
select e.label as doc_name,
          e.url,
           i.item_id,
           'multi' as form_type
    from cr_items i, cr_extlinks e
    where i.parent_id = :comment_id
    and e.extlink_id = i.item_id
   UNION
    select null as doc_name,
           utl_raw.cast_to_varchar2(DBMS_LOB.SUBSTR(r.content, 2000, 1))  as url,
           r.item_id,
           'single' as form_type
    from cr_revisions r
    where r.revision_id IN ( select content_item.get_latest_revision(:comment_id) 
                          from dual);

/

ELLER

var comment_id number
exec :comment_id := 3052753
select e.label as doc_name,
          e.url,
           i.item_id,
           'multi' as form_type
    from cr_items i, cr_extlinks e
    where i.parent_id = :comment_id
    and e.extlink_id = i.item_id
   UNION
    select null as doc_name,
           utl_raw.cast_to_varchar2(DBMS_LOB.SUBSTR(r.content, 2000, 1))  as url,
           r.item_id,
           'single' as form_type
    from cr_revisions r
    where EXISTS (select 'x'
                   from dual
                    where content_item.get_latest_revision(:comment_id) =r.revision_id);


/


  1. MySQL FULL JOIN fungerar inte men HÖGER och VÄNSTER går med fungerar

  2. php - mysql lagrar gammal data

  3. MYSQL close connect kan inte stoppa infogningsaktiviteten

  4. Vad är motsvarigheten till bigint i C#?