Faltan materias para inscripciones fuera de termino

Pero entonces esta funcionando bien!
La operación Inscripción a cursada fuera de término va a recuperar la actividad cuando el período de inscripción haya finalizado.
¿Para que quieren inscribirlo por esta operación si el período de inscripción sigue vigente y lo pueden inscribir por la operación normal de inscripción a cursada?

No el periodo de inscripcion ya paso, la aclaracion te la hago porque quizas te podria orientar para encontrar la solucion que hasta ahora no lo pude resolver con lo que me mandaste a probar.

No existe y en la ultima query devuelve otras materias menos la materia en cuestion
1709 Administración y Comercialización 0
1685 Agrometeorología 0
1708 Animales de Granja I 0
0901 Análisis y Producción del Discurso 0
0402 Ecología 0
0395 Economía General 0
0404 Edafología 0
0387 Matemática I 0
1706 Producciones Vegetales Intensivas I 0
1707 Producción Bovina 0
0420 Química I 0

Lorena, igual sigo sin entender, porque cuando te solicite que pruebes estos dos procesos:

Execute procedure sp_matInscCursa_ft (<unidad academica>, <nro de inscripcion>, 'X',1);
Execute procedure sp_matInscCursada (<unidad academica>, <nro de inscripcion>, 'X',1);

Comentaste que en ningun devolvia la materia.
Cuando el 2do procedure es el que se utiliza en la inscripción a cursada normal, es decir cuando existe un período de inscripción vigente.

¿La fecha de inactivacion del período lectivo, cuando es? Debe ser mayor o igual a la fecha actual para que devuelva la materia en cualquiera de las dos operaciones.

 SELECT amt.materia,
                     amt.nombre_materia,
                     amt.credito
                FROM sga_atrib_mat_plan amt
               WHERE amt.unidad_academica = <UNIDAD_ACADEMICA>
                 AND amt.carrera = <CARRERA>
                 AND amt.plan = <PLAN>
                 AND amt.version = <VERSION>
                 AND amt.tipo_materia <> 'G'

¿Esta query devuelve esa actividad?

Alejandro, respecto a los stored yo te respondi que el segundo no me devolvia la materia en cuestion pero si devuelve en las que esta inscripto el alumno
La fecha de inactivacion es el 16 de Julio de 2021
Y la query me devuelve todas las materias INCLUIDA la del problema que es la 0324.

La query que me pasaste en el posteo anterior en donde se fija primero en sga_atrib_mat_plan y despues en si tiene creada comisiones, por separado me devuelve la materia pero al ejecutarla completa no la devuelve, no se si se entiende

  1. ¿Y la siguiente query devuelve la materia?
    (lo unico que cambia de la query anterior es que se agrega que la materia tenga una comision con un periodo lectivo cuya fecha de inactivación sea mayor o igual a hoy y ademas que la comision tenga la inscripción habilitada)
 SELECT amt.materia,
                     amt.nombre_materia,
                     amt.credito
                INTO vcMateria,
                     vcMateriaNombre,
                     vcCredito
                FROM sga_atrib_mat_plan amt
               WHERE amt.unidad_academica = vcUnidadAcademica
                 AND amt.carrera = vcCarrera
                 AND amt.plan = vcplan
                 AND amt.version = vcVersion
                 AND amt.tipo_materia <> 'G'
                 -- CONDICION DE QUE LA MATERIA TENGA DEFINIDA UNA COMISION
                 AND EXISTS (SELECT ''
                               FROM sga_comisiones com,
                                    sga_periodos_lect per
                              WHERE com.unidad_academica   = vcUnidadAcademica
                                AND per.anio_academico     = com.anio_academico
                                AND per.periodo_lectivo    = com.periodo_lectivo
                                AND com.insc_habilitada    = 'S'
                                AND per.fecha_inactivacion >= TODAY 
                                AND amt.materia            = com.materia )

                 ORDER BY amt.nombre_materia
  1. ¿Que devuelve este parametro?
EXECUTE PROCEDURE sp_param_sistema('filtro_materias_con_comision') 

La query me devuelve las comisiones y el parametro esta en S. La comision fue creada como la del resto de las materias, donde deberia ver si esta restringida?

¿Esto devuelve la materia?

SELECT amt.materia,
                     amt.nombre_materia,
                     amt.credito
                FROM sga_atrib_mat_plan amt
               WHERE amt.unidad_academica = 
                 AND amt.carrera = 
                 AND amt.plan = 
                 AND amt.version = 
                 AND amt.tipo_materia <> 'G'
                 -- CONDICION DE QUE LA MATERIA TENGA DEFINIDA UNA COMISION
                 AND EXISTS (SELECT ''
                               FROM sga_comisiones com,
                                    sga_periodos_lect per
                              WHERE com.unidad_academica   = vcUnidadAcademica
                                AND per.anio_academico     = com.anio_academico
                                AND per.periodo_lectivo    = com.periodo_lectivo
                                AND com.insc_habilitada    = 'S'
                                AND per.fecha_inactivacion >= TODAY
                                AND amt.materia            = com.materia )

                 ORDER BY amt.nombre_materia

No, no la devuelve- Esto es lo que devuelve y no esta la materia 0324

1709 Administración y Comercialización 0
1685 Agrometeorología 0
1708 Animales de Granja I 0
0901 Análisis y Producción del Discurso 0
0402 Ecología 0
0395 Economía General 0
0404 Edafología 0
0387 Matemática I 0
1706 Producciones Vegetales Intensivas I 0
1707 Producción Bovina 0
0420 Química I 0

Bueno, entonces es esa condicion.
Esa materia NO tiene al menos una comision creada en un periodo lectivo cuya fecha de inactivación sea mayor o igual a la fecha actual y que la inscripción este habilitada.

Me habias dicho que si tiene comision, que esta habilitada la inscripción y que la fecha de inactivación del periodo lectivo es mayor a hoy. ¿Podes volver a verificar esto?

Si, ahi te mando las capturas


comisiones.png

comisiones.png

fechas.png

fechas.png

Lorena, perdon pero perdi el hilo de este post.
¿Esta consulta (le saque la condicion del AND EXISTS (…), devuelve la materia para la version del plan de estudios del alumno?

SELECT amt.materia,
                     amt.nombre_materia,
                     (SELECT count(*)
                               FROM sga_comisiones com,
                                    sga_periodos_lect per
                              WHERE com.unidad_academica   = amt.unidad_academica
                                AND per.anio_academico     = com.anio_academico
                                AND per.periodo_lectivo    = com.periodo_lectivo
                                AND com.insc_habilitada    = 'S'
                                AND per.fecha_inactivacion >= TODAY
                                AND amt.materia            = com.materia) as existen_comisiones
                FROM sga_atrib_mat_plan amt
               WHERE amt.unidad_academica = <UNIDAD_ACADEMICA>
                 AND amt.carrera = <CARRERA>
                 AND amt.plan = <PLAN>
                 AND amt.version = <VERSION>
                 AND amt.tipo_materia <> 'G'

No hay problema, si la devuelve

¿Y que valor devuelve en la columna existen_comisiones?

Te adjunto el codigo del procedure de la ultima version. Crearlo y fijate si ejecutando ese procedure devuelve la materia.


sp_matInscCursa_ft.sql (17.6 KB)

En existen comisiones dice 0!!!, el stored ya lo habia corrido que me lo mandaste en un post anterior y no funciona

Si devuelve 0 es porque esa condición entonces es la que hace que no devuelva materias y es lo correcto.

Pero algo no me cierra. ¿Estas segura que las imágenes que enviaste del Periodo lectivo y de esas comisiones de la materia son de la misma base que estas probando estas consultas?

En la imagen del ABM de Periodos Lectivos, el nombre del periodo lectivo es 1° cuatrimestre.
En el ABM de Comisiones, el nombre del periodo lectivo es 1° CUATRIMESTRE
¿Tendras dos 1er cuatrimestre?

Si te desconcierta, ahi volvi a chequear y si es la misma base

Fijate lo que te comente en el mensaje anterior.

Si seguis con problemas, cambia el parametro filtro_materias_con_comision, para que no filtre las materias que no tienen comisiones. Y fijate si devuelve la materia. Igual es una solución que no soluciona el problema en si, porque te mostrará la materia pero luego no te mostrará la comision porque por lo que veo no hay comisiones vigentes.

Hay un solo periodo 1er cuatrimestre , no se porque lo muestra todo con mayuscula despues. Si efectivamente no encuentra la comision aunque esta creada, y aunque de de alta una comision nueva tampoco la reconoce…

Quizas lo de mayuscula es solo un tema de visualización, intente buscarlo pero no lo encontré.
En la imagen que enviaste hay 3 comisiones para esa materia, y de esas dos con inscripción habilitada.
Si cambias el parametro hará que no realice ese filtro y que recupere las materias. ¿Probaste?