Ver Mensaje Individual
  #18  
Antiguo 25-10-2008
Avatar de Delphius
[Delphius] Delphius is offline
Miembro Premium
 
Registrado: jul 2004
Ubicación: Salta, Argentina
Posts: 5.582
Reputación: 27
Delphius Va camino a la fama
Cita:
Empezado por lKinGl Ver Mensaje
aja delphius pero tu dices:
xaula tiene xhoras desocupadas verdad?

pero que horas?,por que puede ser q en el aula2 haya, clase el lunes de 7-9 y de 10-12 pero como detectar que el aula esta disponible de 9-10

esa es mi inquietud....

salu2
Bueno, lKinGl ¿Y acaso no puedes hacer una consulta que extraiga las clases que si están?

A lo que voy lKinGl es que la información está; Y en ciertos casos, la ausencia de información es una información muy valiosa. ¿Me explico?

Hay una frase que dice: "la falta de evidencias es una evidencia" En cuanto a este caso, la falta de ese dato de las horas libres es un dato... y como tal puede obtenerse.

Lo que deberías preguntarte es ¿que es detectar para ti? ¿Bajo que contexto deberíamos interpretarlo?

El diseño que yo te ofrecí es simple, pero como todas las cosas algo en contra tiene. Y como he dicho, guardar X y guardar Y-X es redundante. O lo uno u lo otro, ambos terminarían siendo lo mismo puesto que ofrecen la misma respuesta pero desde puntos de vista opuestos.

¿No se puede dejar a interpretación del usuario? Puesto que si se puede obtener datos sobre las horas ocupadas, es posible armar un diseño visual (por ejemplo) en donde se muestre el horario.

Y de hecho, lKinGl, se puede calcular. Como he dicho, cuestión de programación. Tal vez con un SQL resulte rebuscado, pero he aqui que con Delphi puede conseguirse. ¿Cómo?

Una opción: implementar un algoritmo que recorra el conjunto de datos (ordenado) devuelto por una Query e ir calculando los horarios en blanco. ¿Se puede? ¡Claro! ¡Si los datos están!

lKinGl, piensa... piensa. No es por malo, pero el dato está; de una u otra "forma" pero está.

Veamos como te lo puedo "graficar":

Supongamos que la tabla Aulas además de dichos campos mencionados anteriormente tiene dos campos más (necesarios):
HoraInicio
HoraFin

Teniendo estos dos campos se puede establecer un marco temporal.

Además la tabla Horarios tiene un campo HoraInicio, cuyo propósito es registrar la hora en que se da comienzo la actividad.

Con estos campos es posible ya, implementar un algoritmo que vaya examinando registro a registro y calculando la diferencias de horas, estas diferencias de horas puede proporcionar un conjunto con las horas libres.

Por ejemplo, supongamos que HoraIncio y HoraFin de un aula es 08:00 y 18:00 respectivamente.

Mantengo en una variable InicioClase el valor inicial:
InicioClase = Aula.HoraInicio
InicioClase = 08:00

El primer registro de los horarios nos dá estos datos:
Horarios.HoraInicio = 09:00
Horarios.Duracion = 1

Entonces, evaluamos:
Horario.HoraInicio > InicioClase
09:00 > 08:00

Como es verdadero, estamos en presencia de una hora libre:
HoraLibre = HoraLibre + 1

Creamos un "registro" y calculamos la duracion:
HoraLibres[HoraLibre].Duracion = Horario.HoraInicio - Aula.HoraInicio
HoraLibres[1].Duracion = 09:00 - 08:00 = 1

//Comentario: Yo hice, de manera simple que se trata de un array....

Calcula la nueva hora de inicio a clase
InicioClase = Horario.HoraInicio + Horario.Duracion
InicioClase = 09:00 + 1 = 10:00

Ahora me muevo al siguiente registro, y leo:
Horario.HoraInicio = 10:00
Horario.Duracion = 2

Al evaular tenemos:
Horario.HoraInicio > InicioClase
10:00 > 10:00

Al ser falso, es evidente que no estamos en una hora libre. Directamente calculo la siguiente hora de incio a clase:
InicioClase = Horario.HoraInicio + Horario.Duracion
InicioClase = 10:00 + 2 = 12:00

Me muevo al siguiente registro y vuelvo a evaluar...

Y asi se continua mientras haya registros, o en otro caso, se supere la hora de fin destinadas al aula.

¿Se entiende el algoritmo? ¿Está la información lKinGl?
Como vez, no todo es SQL, en ocasiones Delphi tiene que trabajar un poquito más

Saludos,
__________________
Delphius
[Guia de estilo][Buscar]
Responder Con Cita