![]() |
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. |
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) |
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.
|
has usado la clausula Distinct ? para que te jale solo 1 registro?
|
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. |
pruebalo asi y comentas |
Sql
Disculpe la pregunta pero que significa ese size "2".
A la espera de su comnetario |
disculpa, lo que pasa es que habia copiado y pegado tu query y me salio todo ese codigo que viste... pero ya lo edite
|
Sql
Estimado este es el codigo que me iva a mandar por que lo e probado y me sigue saliendo el mismo error.
selectDISTINCT 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; |
Por favor, lee nuestra guía de estilo, gracias por tu colaboración.
|
que base de datos estas usando?
|
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. |
podrias colocar los campos que tienes en tu tabla History ?
a ver si ideamos otro metodo de sacar la informacion |
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] |
y si cambias al forma?
te hago la consulta aproximada (no es necesariamente asi usa tus campos)
eso te mostrara el personal con las 4 marcaciones 1 en cada columna.. repito... es un pseudocodigo, tu debeas usar tus campos |
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 |
no puedo darte todo el codigo porque no conozco las estructuras de tus tablas....
|
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 |
Sql
Estimado una consulta ese que es hora y horario solo es la hora o que pues.
A la espera de tu ayuda |
es la hora
|
Sql
Estimada Caro.
Si tienes razon me trae dos datos el cual es ahi es donde se cae el query, necesito su ayuda para resolver este tema gracias. Urgente |
Cita:
Cita:
Saluditos |
Sql
Estimada Caro.
Este es mi query que e desarrollado pero justo en el select anidado se me cae ya que cuando coapara y por desir el primer select en inicio se da cuenta que el usuario a marcado 2 veces es ahi donde se cae. Dame una ayudadita sisisis. 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 ,[Estado_per]Estado ,[Cod_Finger]FingerID FROM T_Personal where [NomProy_per]='BMP' and NomArea_per='Sistemas' and Estado_per='Activo')r; |
Sql
Estimado este es el query que e desarrollado con tu ayuda pero me trae errores que me sale en la fila 5 y 24.
select r.*,convert(char(10),GETDATE(),112) FechaActual, (SelectDistinct T.UserID, T.UserName,CaseWhen h.fKey ='Entrada'then h.LogTime else 0 end)As Entrada, CaseWhen h.fKey ='InicioAlmuerzo'then h.LogTime else 0 end)As Inicio, CaseWhen h.fKey ='FinAlmuerzo'then h.LogTime else 0 end)As Fin, CaseWhen h.fKey ='Salida'then h.LogTime else 0 end)As Salida From History T LeftJoin LogTime h on T.UserID = H.UserID Where H. LogDate ='2011/05/17') 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; |
Te recuerdo de nuevo nuestras normas y recuerda poner etiquetas al código.
Gracias por tu colaboración. ![]() . |
Sql
Estimado este es el query que e desarrollado con tu ayuda pero me trae errores que me sale en la fila 5 y 24.
select r.*,convert(char(10),GETDATE(),112) FechaActual, (SelectDistinct T.UserID, T.UserName,CaseWhen h.fKey ='Entrada'then h.LogTime else 0 end)As Entrada, CaseWhen h.fKey ='InicioAlmuerzo'then h.LogTime else 0 end)As Inicio, CaseWhen h.fKey ='FinAlmuerzo'then h.LogTime else 0 end)As Fin, CaseWhen h.fKey ='Salida'then h.LogTime else 0 end)As Salida From History T LeftJoin LogTime h on T.UserID = H.UserID Where H. LogDate ='2011/05/17') 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; |
Sql
Amigo este codigo se diseño con tu ayuda pero me sale error en la fila 5 y 24 ayuda
select r.*,convert(char(10),GETDATE(),112) FechaActual, (SelectDistinct T.UserID, T.UserName,CaseWhen h.fKey ='Entrada'then h.LogTime else 0 end)As Entrada, CaseWhen h.fKey ='InicioAlmuerzo'then h.LogTime else 0 end)As Inicio, CaseWhen h.fKey ='FinAlmuerzo'then h.LogTime else 0 end)As Fin, CaseWhen h.fKey ='Salida'then h.LogTime else 0 end)As Salida From History T LeftJoin LogTime h on T.UserID = H.UserID Where H. LogDate ='2011/05/17') 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; |
Sql
Amigo este es el query que e desarrollado con tu ayuda pero me trae errores que me sale en la fila 5 y 24.
select r.*,convert(char(10),GETDATE(),112) FechaActual, (SelectDistinct T.UserID, T.UserName,CaseWhen h.fKey ='Entrada'then h.LogTime else 0 end)As Entrada, CaseWhen h.fKey ='InicioAlmuerzo'then h.LogTime else 0 end)As Inicio, CaseWhen h.fKey ='FinAlmuerzo'then h.LogTime else 0 end)As Fin, CaseWhen h.fKey ='Salida'then h.LogTime else 0 end)As Salida From History T LeftJoin LogTime h on T.UserID = H.UserID Where H. LogDate ='2011/05/17') 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; |
Te recuerdo de nuevo nuestras normas y recuerda poner etiquetas al código.
Gracias por tu colaboración. ![]() . |
Hola de nuevo, de esta forma es un poco dificil ayudarte, no sabemos la estructura de tus tablas, que datos tienes, ni tampoco cuales son esos dos registros que te devuelve la subconsulta, por lo que tampoco sabemos cual de ellos te sirve o si tienes que hacer alguna operación entre ellos.........
Si haces lo que te dije mas arriba de pasarnos un ejemplo, prodriamos inclusive plantear de otra forma la consulta. Lo que se me ocurre, es que le aplique Top 1 a cada una de tus subconsultas, pero nose si sera el resultado que esperas.
Saluditos |
Sql
Estimada para que me puedas ayudar que es lo que necesitas pues.
A la espera de tu comentario. ya que es de suma urgencia sisisisis. |
Richard, por favor no repitas el mismo mensaje varias veces y lee lo que te ha indicado Casimiro.
Saluditos |
Sql
Hice las pruebas con tu ayuda pero me sale error con el top 1.
ayudame gracias es urgente |
:o me he equipocado donde he puesto el Top 1.
Saluditos |
Si te esta retornando más de un valor en la sub consulta no dara nunca, creo que a cada una de estas:
el Top 1 indica que sacara solo una fila lo mismo para Salida, etc y con un order by de la hora sacaras el que quieras el primer intento o el segundo. si tendría la estructura de tus tablas sería más facil para mi explicarte. salu2 |
Sql2
Estimadoas
utilice el top 1 y me resulto muhas gracias por la ayuda, ahora si yo quiero ponerle un order by en mi ultima linea me sale que el order by no trabaja en sub consultas ya que quieero ordenarlo por apellido a la espera de su ayuda. select r.*,convert(char(10),GETDATE(),112) FechaActual , (select Top 1 [LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='Entrada'and [LogDate] ='2011/05/17')Entrada, (select Top 1[LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='InicioAlmuerzo'and [LogDate] ='2011/05/17')InicioAlmuerzo, (select Top 1[LogTime]from History as h where [UserID]= r.FingerID AND [FKey]='FinAlmuerzo'and [LogDate] ='2011/05/17')FinAlmuerzo, (select Top 1[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 ,[Estado_per]Estado ,[Cod_Finger]FingerID FROM T_Personal where [NomProy_per]='BMP' and NomArea_per='Sistemas' and Estado_per='Activo')r; |
| La franja horaria es GMT +2. Ahora son las 11:00:53. |
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