sql >> Database teknologi >  >> RDS >> Oracle

Oracle:Venstre join meget stor tabel og begræns de sammenføjede rækker til én med den største feltværdi

prøv dette

SELECT m.*,
       (select s.s_field 
          from t_sub s
         where s.m_id = m.m_id
           and s.s_order = (select max(s_order) from t_sub where t_sub.m_id = s.m_id)
           and rownum = 1)
FROM t_main m

eller du kan prøve dette (det er din kode, men nogle ændringer)

SELECT m.*,
      (select s.s_field from 
       (SELECT s_field, m_id
          FROM t_sub
         --where t_sub.m_id = m.m_id
         order by s_order DESC) s
        where s.m_id = m.m_id
          and rownum = 1)
FROM t_main m


  1. INSTR() Funktion i Oracle

  2. Sådan vælger du data fra en nøgleværdipartabel

  3. Infinite Scroll med MySQL Data

  4. Brug af SELECT UNION og returnering af output fra to kolonner fra én tabel