Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 02-01-2008
Avatar de Gaim2205
Gaim2205 Gaim2205 is offline
Miembro
 
Registrado: ago 2007
Ubicación: Durango, Mexico
Posts: 144
Poder: 17
Gaim2205 Va por buen camino
como integrar estas 2 consultas?

tengo la siguiente consulta:
Código SQL [-]
SELECT distinct
dbo.acum_concepto.trabajador AS 'NO. EMP',
cast(dbo.trabajadores.nombre as char(40)) AS 'NOMBRE',
dbo.trabajadores_grales.fecha_ingreso AS 'F.INGRESO',
dbo.trabajadores.reg_seguro_social AS 'NO. IMSS',
sum(case when Concepto = 1110 then tiempo else 0 end) AS 'D. TRABAJADOS',
sum(case when Concepto = 1110 then importe else 0 end)AS 'SUELDO BASE'
.......
.......
FROM dbo.trabajadores_grales inner join dbo.acum_concepto on
dbo.trabajadores_grales.trabajador = dbo.acum_concepto.trabajador inner join
dbo.trabajadores on dbo.acum_concepto.trabajador = dbo.trabajadores.trabajador 
WHERE 
fecha between '20071101' and '20071125'
group by dbo.acum_concepto.trabajador, dbo.trabajadores.nombre, 
dbo.trabajadores.reg_seguro_social, dbo.trabajadores_grales.fecha_ingreso
order by dbo.acum_concepto.trabajador

aunque se puede pulir un poco, hasta ahora me funciona bien. Despliego los datos en un grid. Ahora quiero integrarle la siguiente consulta para que su resultado aparezca como una nueva columna en el grid:
Código SQL [-]
select top 1 dato1 from hist_integrado where secuencia = 2 and subsecuencia = 0 order by fecha desc

Pero hasta ahora no he tenido mucho exito. Gracias.

Última edición por Gaim2205 fecha: 02-01-2008 a las 20:32:31.
Responder Con Cita
  #2  
Antiguo 02-01-2008
Avatar de poliburro
[poliburro] poliburro is offline
Miembro Premium
 
Registrado: ago 2004
Ubicación: México D.F
Posts: 3.068
Poder: 23
poliburro Va por buen camino
una pregunta para aclarar idea,

quieres que aparezca el mismo resultado de la segunda consulta en todas las filas devueltas por la primera consulta?

o


deseas que la segunda consulta muestre el resultado de acuerdo a cada fila devuelta en la primera consulta?
__________________
Conoce mi blog http://www.edgartec.com
Responder Con Cita
  #3  
Antiguo 02-01-2008
Avatar de Gaim2205
Gaim2205 Gaim2205 is offline
Miembro
 
Registrado: ago 2007
Ubicación: Durango, Mexico
Posts: 144
Poder: 17
Gaim2205 Va por buen camino
jejeje no se si entendi muy bien tu pregunta, pero CREO que esta:
Cita:
deseas que la segunda consulta muestre el resultado de acuerdo a cada fila devuelta en la primera consulta?
explico:

la primera consulta me muestra varios datos de todos los trabajadores de la empresa. El grid me muestra los datos asi

no. emp - nombre - f.ingreso - no.imss - d.trabajados - sueldo base

lo que quiero es que ahora me muestre el "dato1" como una columna mas en ese grid, a cada trabajador le corresponde su "dato1" unico.

Espero haberme explicado bien. Gracias.

Agrego: Lo que me lo hace mas complicado es el "select top 1.... order by desc" porque es un order by innecesario, necesito el ultimo registro pero no puedo hacer que funcione lo contrario al top (que segun yo es bottom :P:S) mi b.d esta en sql server 2000

Última edición por Gaim2205 fecha: 03-01-2008 a las 00:41:07.
Responder Con Cita
  #4  
Antiguo 04-01-2008
Avatar de jcarteagaf
[jcarteagaf] jcarteagaf is offline
Miembro Premium
 
Registrado: abr 2006
Ubicación: La Paz, Bolivia
Posts: 651
Poder: 19
jcarteagaf Va por buen camino
Consulta integrada

Creo que esto es lo que quieres hacer:

Código SQL [-]
SELECT distinct
dbo.acum_concepto.trabajador AS 'NO. EMP',
cast(dbo.trabajadores.nombre as char(40)) AS 'NOMBRE',
dbo.trabajadores_grales.fecha_ingreso AS 'F.INGRESO',
dbo.trabajadores.reg_seguro_social AS 'NO. IMSS',
x.dato1,  // dato1 de la consulta
sum(case when Concepto = 1110 then tiempo else 0 end) AS 'D. TRABAJADOS',
sum(case when Concepto = 1110 then importe else 0 end)AS 'SUELDO BASE'
.......
.......
FROM dbo.trabajadores_grales inner
join dbo.acum_concepto on dbo.trabajadores_grales.trabajador = dbo.acum_concepto.trabajador
inner join dbo.trabajadores on dbo.acum_concepto.trabajador = dbo.trabajadores.trabajador 
join (
  select top 1 dato1 from hist_integrado where secuencia = 2 and subsecuencia = 0 order by fecha desc) x
on dbo.trabajadores_grales.campounionambastablas = x.campounionambastablas

WHERE 
fecha between '20071101' and '20071125'
group by dbo.acum_concepto.trabajador, dbo.trabajadores.nombre, 
dbo.trabajadores.reg_seguro_social, dbo.trabajadores_grales.fecha_ingreso
order by dbo.acum_concepto.trabajador

Saludos
Responder Con Cita
  #5  
Antiguo 04-01-2008
Avatar de Gaim2205
Gaim2205 Gaim2205 is offline
Miembro
 
Registrado: ago 2007
Ubicación: Durango, Mexico
Posts: 144
Poder: 17
Gaim2205 Va por buen camino
Sí eso era lo que buscaba. Muchas Gracias.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Integrar Delphi con AS-400 JELIRM Varios 7 13-04-2007 17:48:59
¿Como realizar consultas SQL? seara2005 SQL 2 17-12-2006 02:19:17
Integrar PHP en delphi jam Varios 3 02-12-2006 01:50:37
Como realizo estas busquedas ??? Durbed Conexión con bases de datos 4 04-11-2004 15:16:19
Integrar .hlp en delphi Yenifer Varios 1 24-08-2004 14:10:33


La franja horaria es GMT +2. Ahora son las 20:16:42.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi