Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   MS SQL Server (https://www.clubdelphi.com/foros/forumdisplay.php?f=23)
-   -   Sql (https://www.clubdelphi.com/foros/showthread.php?t=73819)

Richard Lopez G 18-05-2011 16:39:12

Sql
 
Estimados tengo mi Query con select anidados que he realizado con dos tablas como se muestra lineas abajo que son dos, este query trata de la asistencia del personal el cual hago la busuqeda en el primer select donde esta la tabla History hago la comparacion de fechas el problema es el siguiente que de casualidad un usuario marca dos veces sus asistencia el query me da error ya que solo busca un dato y no dos como me pueden ayudar en este tema.

select
r.*,convert(char(10),GETDATE(),112) FechaActual ,
(
select [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='Entrada'and [LogDate] ='2011/05/17')Entrada,
(
select [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='InicioAlmuerzo'and [LogDate] ='2011/05/17')InicioAlmuerzo,
(
select [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='FinAlmuerzo'and [LogDate] ='2011/05/17')FinAlmuerzo,
(
select [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='Salida'and [LogDate] ='2011/05/17')Salida
FROM
(SELECT [Cod_per]CodPersonal
,[ApePat_per]ApellidoPaterno
,[ApeMat_per]ApellidoMaterno
,[Nom_per] NombrePersonal
,[NomProy_per]Proyecto
,[NomArea_per]Area
,[NomCargo_per]Cargo
,[Estado_per]Estado
,[Cod_Finger]FingerID
FROM T_Personal
where [NomProy_per]='BMP'
and NomArea_per='Contabilidad'
and Estado_per='Activo')r;

el error es el siguiente que me da por ese inconveniente

Msg 512, Level 16, State 1, Line 1
La subconsulta ha devuelto ms de un valor, lo que no es correcto cuando va a continuacin de =, !=, <, <=, >, >= o cuando se utiliza como expresin.

oscarac 18-05-2011 16:51:19

saludos

primero que nada da una rapida visita a la guia de estilo

segundo..... podrias usar quiza distinct para capturar un solo registro, el problema radica, en que registro jalar si el primero o el segnudo (me imagino que el primero)

Richard Lopez G 18-05-2011 16:55:01

Sql
 
Estimado muchas gracias por tu concejo, pongamoslo que jale el ultimo registro me podrias ayudar en el codigo por favor es de suma urgencia para el dia de hoy.

oscarac 18-05-2011 16:58:02

has usado la clausula Distinct ? para que te jale solo 1 registro?

Richard Lopez G 18-05-2011 17:00:03

Sql
 
Amigo lo que pasa es que soy nuevo en este tema del SQL y la verda que no usado el distinct, me podrias ayudar con mi codigo por favor.

A la espera de tu comentario.

oscarac 18-05-2011 17:02:41

Código SQL [-]
Select DISTINCT .... y lo que sigue en tu select

pruebalo asi y comentas

Richard Lopez G 18-05-2011 17:06:20

Sql
 
Disculpe la pregunta pero que significa ese size "2".

A la espera de su comnetario

oscarac 18-05-2011 17:09:09

disculpa, lo que pasa es que habia copiado y pegado tu query y me salio todo ese codigo que viste... pero ya lo edite

Richard Lopez G 18-05-2011 17:11:52

Sql
 
Estimado este es el codigo que me iva a mandar por que lo e probado y me sigue saliendo el mismo error.

select
DISTINCT
r.*,convert(char(10),GETDATE(),112) FechaActual ,
(
select [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='Entrada'and [LogDate] ='2011/05/17')Entrada,
(
select [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='InicioAlmuerzo'and [LogDate] ='2011/05/17')InicioAlmuerzo,
(
select [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='FinAlmuerzo'and [LogDate] ='2011/05/17')FinAlmuerzo,
(
select [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='Salida'and [LogDate] ='2011/05/17')Salida
FROM
(SELECT [Cod_per]CodPersonal
,[ApePat_per]ApellidoPaterno
,[ApeMat_per]ApellidoMaterno
,[Nom_per] NombrePersonal
,[NomProy_per]Proyecto
,[NomArea_per]Area
,[NomCargo_per]Cargo
,[Estado_per]Estado
,[Cod_Finger]FingerID
FROM T_Personal
where [NomProy_per]='BMP'
and NomArea_per='Sistemas'
and Estado_per='Activo')r;

Casimiro Noteví 18-05-2011 17:15:26

Por favor, lee nuestra guía de estilo, gracias por tu colaboración.

oscarac 18-05-2011 17:15:29

que base de datos estas usando?

Richard Lopez G 18-05-2011 17:17:55

Sql
 
Estoy usando el SQL 2005.

El codigo que me mandastes lo prove pero nada que ver me sigue saliendo el mismo error.

Ayuda es urgente, disculpa la molestia

Msg 512, Level 16, State 1, Line 1
La subconsulta ha devuelto ms de un valor, lo que no es correcto cuando va a continuacin de =, !=, <, <=, >, >= o cuando se utiliza como expresin.

oscarac 18-05-2011 17:24:13

podrias colocar los campos que tienes en tu tabla History ?
a ver si ideamos otro metodo de sacar la informacion

Richard Lopez G 18-05-2011 17:32:28

Sql
 
Estos son los campos que estan en mi history y despues lo comparo con la tabla t_Personal que se muestra en el query anterior sus campos

SELECT [Tid]
,[TerminalName]
,[UserID]
,[UserName]
,[LogDate]
,[LogTime]
,[Verify]
,[FKey]
,[DlData]
FROM [RRHH].[dbo].[History]

oscarac 18-05-2011 17:41:44

y si cambias al forma?

te hago la consulta aproximada (no es necesariamente asi usa tus campos)

Código SQL [-]
 
Select Distinct T.CodigoPersonal, T.NombrePersonal, 
Case When h.fKey = 'Entrada' then h.Hora else 0 end) As Entrada,
Case When h.fKey = 'InicioAlmuerzo' then h.Hora else 0 end) as Inicio,
Case When h.fKey = 'FinAlmuerzo' then h.Hora else 0 end) As Fin,
Case When h.fKey = 'Salida' then h.Hora else 0 end) As Salida
From Trabajadores T
Left Join Horarios h on T.CodigoPersonal = H.CodigoPersonal
Where H.Fecha = '2011/05/17'

eso te mostrara el personal con las 4 marcaciones 1 en cada columna.. repito... es un pseudocodigo, tu debeas usar tus campos

Richard Lopez G 18-05-2011 17:47:39

Sql
 
Disculpa que te moleste tanto pero todo el codigo como seria, ya que hay cosas que todavia no las entiendo y me es dificil entenderlo.

Ayudame por favor

Gracias

oscarac 18-05-2011 17:59:48

no puedo darte todo el codigo porque no conozco las estructuras de tus tablas....

Caro 18-05-2011 18:04:37

Hola Richard, yo creo que el problema esta en las subconsultas del select, te esta devolviendo mas de un registro, ejecuta cada subconsulta por separado y verifica que solo te devuelva un registro.

Para que te ayudemos mejor, sería bueno que indicaras los campos que tienes con algunos datos y mostrar el resultado que quieres obtener en base a esos datos.

Saluditos

Richard Lopez G 18-05-2011 18:04:53

Sql
 
Estimado una consulta ese que es hora y horario solo es la hora o que pues.

A la espera de tu ayuda

oscarac 18-05-2011 18:07:16

es la hora


La franja horaria es GMT +2. Ahora son las 09:51:25.

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