FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
donde esta el error???
hola amigos!! lo que quiero hacer es lo siguiente:
tengo una tabla de materias, cada materia tiene su id que consta de 3 caracteres ejemplo. 001 tengo otra tabla que se llama Alu-Mat en la cual tengo un campo que se llama cursadas en cual se agrega el id de la materia que se curso ejemplo: 001002003 conforme se cursa una materia se le agregan 3 digitos que son el id de la materia al campo de cursadas bueno lo que yo quiero es comparar el campo de cursadas con un id de la materia seleccionada en un combo y que me muestre el id del alumno(matricula) que no ha cursado esa materia este es el codigo que tengo espero haberme explicado gracias
|
#2
|
||||
|
||||
Hola
La verdad tal vez o lo mas seguro es que no entiendo el problema, por que para mi el problema esta en la manera de hacerlo, creo que se complica mas de lo necesario, siendo realmente simple. Tengo entendido que hay: Materias: 001 002 etc... Alumnos. A B C etc... Bueno un alumno puede cursar varias materias A001003 B002003 C001 Si es asi, como lo entiendo, entonces por que actualizar el campo cursos con todas la materias, es preferible incluir en cursos en vez de actualizar, una vez cursada la materia, se borra y ya. Saludos |
#3
|
||||
|
||||
muy buena idea Caral voy a intentarlo gracias!!
yo te aviso haber como me fue una vez mas gracias!! |
#4
|
||||
|
||||
Perdón que insista, pero mi punto de vista es que es mil veces mejor tener una tabla donde se guarde el ID del alumno y el ID de la materia cursada.
Un simple join a esa tabla te dirá que alumnos han cursado que materias. edito--------- y te ahorrarías mucho de lo que estas tratando de hacer ahora.
__________________
Última edición por ContraVeneno fecha: 27-06-2007 a las 19:04:37. |
#5
|
||||
|
||||
ya hice lo que me dijiste caral
pero me da un problema con el delete es que no me borra los tres caracteres que le pido?? que estoy haciendo mal o que me falta??
|
#6
|
||||
|
||||
hola ContraVeneno
si tengo una tabla como la que tu dices se llama alumat en ella tengo la matricula del alumno y un campo que se llama cursadas en cursadas tengo todos los id de las materias lo que quiero es borrar el id de la materia que se le va a asignar al alumno anteriormente lo estaba haciendo al reves queria añadir los tres caracteres del id de la materia al campo de cursadas pero Caral me dio una mejor idea y es la que es desarrollando gracias por sus criticas me ayudan mucho |
#7
|
||||
|
||||
No me refería a eso. Lo que estas haciendo ahora:
Tener un campo tipo String donde vas agregando el ID de la matrícula, haciendo este string variable. No me parece que sea lo correcto. Mi sugerencia es que tengas una tabla de alumnos y matrículas como ya había explicado en este otro hilo. Donde tendrías un Registro por cada materia cursada y no un solo campo donde cambies su valor cada ves que curse materias. Teniendo esta tabla y un registro por cada materia, no tendrías que andar inventando cosas para comparar, editar, mover o quitar materias de un campo string. Con simples instrucciones Update, Delete o Insert, puedes tener lo que necesitas sin complicartela tanto.
__________________
|
#8
|
||||
|
||||
oye Contra no crees que voy a tener muchos registros son 37 materias por cada alumno imaginate si son 1000 alumnos??? o como vez??
|
#9
|
||||
|
||||
1000 por 37 = 37,000 registros... por 10 años = 370,000 registros...
Habrá muchos de los aquí presentes que te podrían decir que 370,000 registros no son muchos. Además, creo que vale la pena tener 370,000 registros en lugar de batallar una semana tratando de ver como hacer para quitar ciertos caracteres de una cadena. Pero bueno, ojala y alguien tenga otra opinión sobre que es lo mejor en este caso. Vamos, que hasta podrías consultar las reglas de normalización de bases de datos y si quieres que tu base de datos este normalizada, una de las condiciones es que los datos sean atómicos, es decir, que un valor, represente un dato. Y si tienes un valor que representa muchos datos, pues no estarías cumpliendo con estas reglas de normalización.
__________________
Última edición por ContraVeneno fecha: 27-06-2007 a las 20:22:58. |
#10
|
||||
|
||||
pues creo que vale mas la pena perder el tiempo una semana y que las cosas queden bien echas a despues tener problemas de almacenamiento
|
#11
|
||||
|
||||
Hola
Tablas Alumnos, todos los alumnos. IDAlumno, Nombre, direccion, tel, fechaentra, fechasale Materias, todas las materias. IDMateria, Nombre, descripcion, profesor, tipo, etc. Cursos, todos los cursos. IDCurso, Descripcion, profesor, Valorcurso, fechaempieza, fechatermina AlumnoPrograma, alumnos que cursan y materias IDAlumno, IDMateria, IDcurso, Fechaempieza, fechatermina, Notafinal Lo que estoy es tratando de buscar una formula simple de ligar el asunto. Que opinais.? Saludos |
#12
|
|||
|
|||
Cita:
Yo digo, vale mas invertir tiempo en crear una base de datos bien hecha (normalizada), que perder el tiempo buscando corregir inconsistencias por código. Yo me quedo con la opinion de ContraVeneno. Salud OS.
__________________
"La forma de empezar es dejar de hablar y empezar a hacerlo." - Walt Disney |
#13
|
||||
|
||||
Hola,
Al igual que Egostar estoy a favor de ContraVeneno. Si tanto te preocupa el almacenamiento, podrías buscar otra alternativa de realizar dicha relación. Pero no aplicando esos artilugios que al mediano y largo plazo no sirven de nada. ¿Que harias si una materia deja de dictarse, o por el contrario, se agregan nuevas? Si lo vemos desde el punto de vista del negocio o dominio (como prefieran llamarle) vemos que uno o más alumnos están incriptos en una o más materia. Un grupo de alumnos incriptos en una materia pueden formar una comisión. ¿Que se desprende de este texto? Que ya sea en forma directa o indirecta existe una asociación entre los alumnos. El análisis de dominio puede que no te haya relevado la existencia directa o explícita de relaciones. Puede que en la auditoria o análisis de campo, no se haya dicho exactamente la palabra comisión ya que según la visión del cliente o la realidad que éste tiene del negocio no le es relevante el concepto y por tanto "carece de sentido guardar algo que no le es útil" A lo que voy es que la transformación M-M entre alumnos y estudiantes puede realizarse con otro enfoque: Varios alumno se incriben a una comisión. Dicha comisión puede pertenecer a una o más materias. Esto puede reducir la cantidad de registros entre la antigua relación M-M ya que la asociación entre los estudiantes y las materias se ha desplazado y agrupado bajo otra tabla. Otra cosa es si es necesario hacerle saber al usuario el concepto "comisión". Tu verás, realizar un buen análisis del dominio o negocio puede aportarte nuevos enfoques y descubrir la manera óptima de como realizar las relaciones entre los datos. Saludos, y que tenga exitos. |
#14
|
||||
|
||||
Cita:
__________________
|
#15
|
||||
|
||||
Hola
Si, El curso tiene fecha inicio y fecha final, pero el alumno terminara el curso o lo dejara a medias, es una posibilidad, otra es que el curso comience el 1 y el alumno lo comience el 3, el curso termine el 20 y el alumno no lo termine, por x razon. Te parece logico? Saludos |
#16
|
||||
|
||||
Claro, viéndolo de esa manera, sí me parece lógico.
Ahora, la verdadera intensión de mi cuestionamiento respecto a las fechas, era tratar de demostrar como las posibilidades aumentan de manera dramática al utilizar una tabla especialmente diseñada para esto. Se pueden guardar la calificación, el profesor, el tiempo, etc, etc. Esto haciendo más facil los reportes. Cosa que es imposible de hacer si se guardan las materias cursadas en un solo campo tipo cadena.
__________________
|
#17
|
||||
|
||||
hola caral y amigos que se interesaron por este tema
mi base de datos es practicamente igual a la idea que tu me dices a esepcion que yo tengo un campo cursadas en donde van todos los id de las materias el lugar de un solo id de materia gracias!! creo que me han convencido |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
¿Donde está Rusia? | D-MO | Humor | 1 | 27-07-2006 20:53:11 |
Donde esta mi post? | aupaneu | Conexión con bases de datos | 2 | 31-05-2006 13:56:08 |
Acertijo en PHP. ¿Donde esta el error? | papulo | PHP | 3 | 30-11-2005 19:47:28 |
donde está el error? :S | jorodgar | Varios | 7 | 17-06-2005 16:32:08 |
Donde esta el error ?? | tgsistemas | SQL | 2 | 31-01-2005 15:29:34 |
|