Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   Porque sale null esta consulta?? (https://www.clubdelphi.com/foros/showthread.php?t=90692)

darkamerico 14-08-2016 02:45:01

Porque sale null esta consulta??
 

Al González 14-08-2016 03:41:34

Desconozco qué motor de base de datos utilizas (es importante aclarar ese dato) pero, comúnmente, cuando el resultado de una consulta Select devuelve una columna con valor de Null es porque la expresión con que se obtiene está involucrando un valor Null.

Si haces Null + 5 el resultado será Null; muchas operaciones sobre valores Null regresan como resultado Null. Me parece que eso es parte del estándar del lenguaje SQL.

Sin embargo, revisando tu sentencia, no parece a simple vista que haya un valor Null involucrado. Más bien pareciera que la aparente función TIME_FORMAT no reconoce, o interpreta de forma inesperada, el formato que le estás dando. ¿Qué significa ese %i?

Un abrazo selectivo. :p

Al González.

darkamerico 14-08-2016 03:51:14

Saludos Al Gonzales
 
Amigo gracias por responder, estoy usando MySQL 5.6.16 - MySQL Community Server (GPL).
Referente a los parametros de Time_Format segun la documentacion que revise en (http://www.techonthenet.com/mysql/fu...ime_format.php), tenemos que:

Value Description
%f Microseconds (000000 to 999999)
%f is available starting in MySQL 4.1.1
%H Hour (00 to 23 generally, but can be higher)
%h Hour (00 to 12)
%I Hour (00 to 12)
%i Minutes (00 to 59)
%p AM or PM
%r Time in 12 hour AM or PM format (hh:mm:ss AM/PM)
%S Seconds (00 to 59)
%s Seconds (00 to 59)
%T Time in 24 hour format (hh:mm:ss)

Es extraño, porque esa consulta arroja null en ciertos casos y en otros no.

Un Abrazo

Casimiro Notevi 14-08-2016 12:14:34

Mira el valor de hora_ini, seguro que es nulo en los casos en que el resultado es nulo.

Al González 14-08-2016 19:18:28

Cita:

Empezado por Casimiro Notevi (Mensaje 507669)
Mira el valor de hora_ini, seguro que es nulo en los casos en que el resultado es nulo.

Pero en ese caso, la tercera columna tendría que ser Null, también. :confused:

Yo de MySQL no sé gran cosa. Lo evito siempre que es posible.

Casimiro Notevi 14-08-2016 19:30:30

Cita:

Empezado por Al González (Mensaje 507672)
Pero en ese caso, la tercera columna tendría que ser Null, también. :confused:
Yo de MySQL no sé gran cosa. Lo evito siempre que es posible.

Cierto, no me había fijado en eso, entonces debe ser lo que has comentado antes, time_format

AgustinOrtu 14-08-2016 19:44:48

Prueba la funcion usando valores predeterminados, en lugar de un valor de un registro

fjcg02 14-08-2016 22:37:11

Según observo, el valor sería negativo. Seguro que es por eso.
Now= 19:38:37
Hora_ini= 19:39:00

Saludos

mamcx 15-08-2016 03:32:16

Aunque mysql tiene la fama de "seguir adelante no importa si los datos se corrompen", no veo el problema. Corri eso en:

http://sqlfiddle.com/#!9/9eecb7d/74119

Y dio un resultado ok. Lo unico que se me ocurre es que id_horario no devuelva resultados.

AgustinOrtu 15-08-2016 04:13:59

Otra cosa que se puede hacer es considerar usar alguna de las funciones para fecha/hora

Por ejemplo DATEDIFF

roman 15-08-2016 19:17:56

Cita:

Empezado por darkamerico (Mensaje 507663)

Según puedes ver aquí, si un valor de tipo TIME es usado en un contexto numérico (como en la resta), el valor es convertido a un valor así:

10:41:36 => 104136

Al hacer la resta, en tu caso, obtienes: 193900 - 193837 = 63, que es lo que le pasas a TIME_FORMAT, pero 63 no es un valor correcto de tiempo y de ahí que te devuelva NULL.

Usa las funciones adecuadas, tal como te comenta AgustinOrtu. Siguiendo el ejemplo de mamcx:

http://sqlfiddle.com/#!9/9eecb7d/74248

LineComment Saludos

gguerrini 16-08-2016 22:35:19

Hola Buenas Tardes, te comento las pruebas que hice. Crree una tabla llamada HORARIO en MySQL con dos campos uno DateTime y el Otro de Tipo TIME, Hice las pruebas que pusiste en el foro, y me arrojo estos resultados. Si trabajas con la variable del tipo DATETIME te arroja cero 00:00:00 o cualquiera, cuando lo hice con la TIME me dio tu NULL. Ya que es del tipo time no se usa la funcion TIME() ya que es time. Entonces lo use directo

Código SQL [-]
SELECT TIME_FORMAT( Hora_ini2 - NOW() , '%H:%i:%s') AS diferencia , Hora_ini2 - TIME(NOW()), Hora_ini1
FROM Horario

Y funciono OK. Espero que te sirva. Saludos

Casimiro Notevi 16-08-2016 23:06:43

Recuerda poner los tags al código fuente, ejemplo:



Gracias :)

darkamerico 18-08-2016 02:28:08

Muchas Gracias A Todos
 
Gracias A Todos Por Responder, Me Siento Afortunado De Pertenecer A Esta Comunidad

Un Fuerte Abrazo General

=)


La franja horaria es GMT +2. Ahora son las 16:52:15.

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