Ver Mensaje Individual
  #3  
Antiguo 23-07-2011
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.734
Reputación: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Te recomiento que utilices alias para referirte a las tablas.

Luego sería recomendable que pusieras el alias delante de los campos para que no haya ambigüedades.
Me refiero a ART_Id y ALM_Id y TMO_Tipo. Si existen en mas de una tabla no sabrá a cual te refieres. ART_Id por ejemplo puede estar dentro de la tabla Movimientos y de TiposMovimientos.

Utilizas ALM_Id in ('7'). Si es solo uno, es mucho más eficiente utilizar ALM_Id='7'

Código SQL [-]
select V.*,
  ( (SELECT 
           sum(M.MOV_Cantidad) AS EntradaDeProductos
     FROM Movimientos M
     INNER JOIN TiposMovimientos T
     ON (M.TMO_Id = T.TMO_Id)
     where 
     M.ART_Id = V.VAR_Id  and
     M.ALM_Id in ('7') and 
     T.TMO_Tipo = 'Entrada'
    )
  )
  ,
  ( (SELECT 
           sum(M.MOV_Cantidad) AS EntradaDeProductos
     FROM Movimientos M
     INNER JOIN TiposMovimientos T
     ON (M.TMO_Id = T.TMO_Id)
     where 
     M.ART_Id = V.VAR_Id  and
     M.ALM_Id in ('7') and 
     T.TMO_Tipo = 'Salida'
    )
  )
from Variantes V
where V.ART_Id = '2523'

De todos modos, habría que ver el PLAN que te devuelve, para saber que índices está tomando.
Si nos das esos datos quizás podamos ayudarte.

El select que mencionas en el segundo post sería:
Código SQL [-]
select t1.*, (select col from tabla2 where id=t1.id) from tabla1 t1
Debes utilizar un alias para referirte a una u otra tabla.
Responder Con Cita