![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
|||
|
|||
|
ahhh ok, estemmm no se si sea posible estructurar mejor los campos de la tabla pero esta es la problematica:
en mi universidad necesitan un sistema pequeño que permita la distribucion de las cargas academicas y aulas de modo que no exista ninguna colisión y lo que llevo es en la tabla, las aulas máximo por dia se usan 17 horas, para evitar las colisiones con las horas de las aulas, necesito saber a quehora entra 1profesor y a que hora sale, y aque hora entra el otro y a que hora sale para evitar lo choques de horarios Horas I.1 = Hora de Ingreso1 Horas F.1= Hora de Final 1 asi hasta 17 (Nº de horas maximo de uso por aula). nada mas hay son 34 campos y son 37, no se que otra forma se te ocurre ![]() estoy manejando horas militares enteras(01,02...22,23,24), para facilitar el sistema abierto a sugerencias ![]()
__________________
Las cosas o son, o no son... |
|
#2
|
||||
|
||||
|
Cita:
Yo más bien veo tres tablas: Profesores - 1 --- * - Horarios - * --- Aulas - Es decir, que entre las tabla Profesores y Aulas existe una relación M-M, por tanto se añade la tabla intermedia y se consigue una relación 1-M entre Profesores y Horarios y de igual modo entre Aulas y Horarios. Los campos, me parecen que son bastantes sencillos de entender. El tema de la "colisión" es ya un aspecto de programación. Saludos, |
|
#3
|
|||
|
|||
|
esas exactamente son las tablas que tengo hechas, existen el campo que las relaciona como tu dices, pero lo que tu ves largo son el trato con las horas, que por cierto no creo que me este quedando bien del todo, ya que de la forma como lo llevo hay que alimentar de horas las aulas 1 por 1 pero se da el caso de que hay materias que no tienen 1 hora sino 2 o 3 y hay sino se como hacer.....
__________________
Las cosas o son, o no son... |
|
#4
|
||||
|
||||
|
Cita:
¿Quieres decirme que esos son los campos de la tabla horarios? Pues, yo no lo veo conveniente. Yo lo veo así: AULAS ------ IDAula Nombre .... PROFESORES ------------ IDProfesor Nombre ... HORARIOS ---------- IDHorario AulaID -> FK ProfesorID -> FK Fecha (*) Duracion ---> representa la duración del cursado .... (*) Este campo Fecha llevará el día (dd/mm/aaaa). Tal vez, si el diseño lo amerita, el campo no deba ser de esta forma. Supuestamente los horarios se establecen para la semana y queda fijo por lo que es posible tener esto: Código:
DiaSemana - 1 --- * - Horarios - * ---- 1 - Aulas
|
*
|
1
|
Profesores
DiaSemana ---------- IDDiaSemana Nombre De este modo se puede tener algo como: 1 - Lunes 2 - Martes ... ¿Se entiende la idea? Para tener referencia a esas 17 horas, lo que se puede hacer es tener un campo en la tabla Aulas que lleve la cantidad de horas permitidas. El asunto, como dije antes es una cuestión de programación, armar las SQLs de forma apropiada, y ofrecer los medios necesario de control. Saludos, |
|
#5
|
|||
|
|||
|
ufff men no entiendo nada :S
no se, pienso que seria bueno así, horainicio del dia y horafinal pero como hago si el aula se utiliza de 7:00 a 8:00 y de 8:00 a 9:00 esta desocupada :S gracias adelantadas
__________________
Las cosas o son, o no son... |
|
#6
|
||||
|
||||
|
pues mejor que te lo explico delphius no creo que nadie lo haga, leelo de nuevo y fijate en lo que te dice alli esta la solucion
__________________
...Yo naci en esta ribera del arauca vibr@d0r Soy hermano de la espuma, de la garza, de la rosa y del sol... Viva Venezuela |
|
#7
|
|||
|
|||
|
Hola de nuevo, coincidiendo con delphius, es una manera poco elegante y bastante 'trabajosa' de trabajar. Personalmente haria
tabla 'horas': - id horas (de primary key) - dia de la semana : string - materia : string - aula : string o integer - inicio : TTime - profesor : string de esta tabla, hacer tantos registros por dias de la semana, aulas y horas en activo necesites. Una vez tuvieses esos registros, haciendo una consulta sencilla podrias encontrar las necesarias. Ej, aula 3, miercoles : select * from horas where aula = 3 and dia_semana = 'miercoles' order by inicio, o bien los dias de algebra: select * from horas where materia = 'algebra'. Tu consulta inicial se reduciria a 'select * from horas.db where aula like ' + QuotedStr(ComboBox1.text)+'%' + '''. Que luego necesites ligar aula a una tabla de aulas o bien profesor a una tabla de profesores, ya seria otra historia. Mas o menos es lo mismo que te conto delphius, solo que explicado de manera diferente. saludos y a ver si te sirve. PD: se suelen llamar a las horas por primera hora, segunda, tercera etc... asi, inicio siendo un entero tambien te serviria y simplificaria. saludos de nuevo. |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| dbexpress Error: unknown error Code '101' | raorre | Conexión con bases de datos | 3 | 13-10-2008 07:53:49 |
| Error General Sql Error lock conflict ...deadlock | Patricio | Varios | 1 | 19-03-2008 14:52:14 |
| error:[Fatal Error] Unit1.pas(7): Unit ZDbcConnection was compiled with a different.. | karaoke | Conexión con bases de datos | 2 | 19-12-2007 10:22:36 |
| ¿Por qué me da este error?Error creating cursor manejador | nuri | SQL | 2 | 01-08-2005 17:30:28 |
| consuta dinamicas en report builder | lledesma | Impresión | 5 | 26-04-2005 11:47:12 |
|