Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Firebird e Interbase (https://www.clubdelphi.com/foros/forumdisplay.php?f=19)
-   -   problema subquery (https://www.clubdelphi.com/foros/showthread.php?t=37208)

cuscus 07-11-2006 00:49:31

problema subquery
 
el problema que tengo es que necesito hacer una subquery despues del from.
esto me funciona perfectamente en oracle, pero en interbase no

select count(*) from (select distinct tabla1.* from tabla1, tabla2 where tabla1.estudio=tabla2.estudio
and tabla2.estudio=8683)

lo necesito asi, porque necsito el numero de registros distintos de la tabla1 o simplenente cambiando el distinct que me diera los de la tabla 2

imaginemos que la tabla1 es de estudiantes y la tabla 2 de notas
si un estudiante tiene 5 notas, poniendo tabla1 en el distinct me devolveria 1, poniendo tabla2 me devolveria 5

como no me deja hacer un select count(tabla1.*) pues no se me ocurre otra manera
podeis echarme una mano?

mlara 08-11-2006 02:09:34

La consulta como está creo que no tiene mucho sentido... creo que así estaría bien:

Código SQL [-]
select count(*) from (select distinct * from tabla1 where estudio=8683)

cuscus 08-11-2006 07:55:00

hola mlara

Gracias por contestar, la consulta que me envias es muy parecida, ya que lo unico que cambia es el select distinct, donde tu solo usas una tabla. Yo puse 2 como ejemplo, ya que los campos del where no tienen porque pertenecer a esa tabla, puedo tener una condicion con campos de distintas tablas. De todas formas en interbase no me funciona el "from (select distinct....) ese es mi problema. La consulta tal como la pongo en oracle me funciona y me da el resultado deseado, el problema es la select despues del from en interbase

tefots 08-11-2006 14:20:33

el problema es q interbase/firebird no deja hacer un select despues de un from , con lo que el subquery hay que hacero dentro del where.

Creo que la consulta en firebird/interbase deberia ser algo asi.

select count(*) from tabla1
where tabla1.codigo in (select distinct tabla2..numero from tabla2 where tabla2.codigo=tabla1.codigo) and tabla1.estudio=8683

saludos.

mlara 08-11-2006 14:25:01

FireBird 2.0 sí permite hacer la consulta:

Código SQL [-]
select count(*) from (select distinct * from Tabla1 ...)

InterBase 7.5 no lo permite.

Acabo de probarlo en ambos.

cuscus 08-11-2006 15:01:54

muchas gracias, tendre que recurrir a hacer un select normal y luego un recordcount, me jode viajar tantos datos para nada, pero no veo otra solucion

kalimero 08-11-2006 17:15:56

Hola.
No das mucha informacion sobre la estructura de tablas.
Haciendo un ejercicio de imaginacion creo que mas o menos esto podria servirte
(o parecido).

Código Delphi [-]
SELECT  idestudiante,count(*) as cuantos 
FROM tablaestudiantes A INNER JOIN tablanotas B ON A.idestudiante=B.idestudiante
GROUP BY A.idestudiante

Saludos

cuscus 08-11-2006 18:04:46

imagina que tenemos 2 tablas de alumnos y de notas

yo quiero poder hacer un count del numero de alumnos que han suspendido al menos una asignatura. Osea si un alumno ha suspendido 3 no quiero que cuente como 3 sino solo como 1, por eso tenia la sql como la tenia , pero como bien decis aqui en interbase no funciona el from(select....

kalimero 09-11-2006 10:50:18

Código Delphi [-]
SELECT E.idEstudiante,MIN(nota)
FROM
Estudiantes E INNER JOIN Notas N ON E.idEstudiante=N.idEstudiante
GROUP BY E.idEstudiante
HAVING MIN(DECENTREGADOS) < 5

Con esta consulta obtienes los estudiantes que han suspendido y su nota mas baja. Es decir que si uno tiene dos notas por debajo de 5, solo te saca la mas baja.
Obviamente un "count" no tiene mucho sentido porque siempre va a ser uno.

Saludos

cuscus 09-11-2006 11:09:52

gracias kalimero, pero yo necesito el numero de estudiantes que cumplen esa condicion, por eso tenia el count

un saludo

kalimero 09-11-2006 11:38:01

pues:
Código Delphi [-]
SELECT count(*) as cuantos FROM
(
 SELECT E.idEstudiante
 FROM
 Estudiantes E INNER JOIN Notas N ON E.idEstudiante=N.idEstudiante
 GROUP BY E.idEstudiante
 HAVING MIN(nota) < 5
)

cuscus 09-11-2006 12:12:17

y llegamos al problema que planteo, que no deja en interbase hacer un
"from (select....."
jejeje hemos llegado a el punto de origen, busco una alternativa ya que esa estructura me da error

kalimero 09-11-2006 12:40:43

Bueno la verdad es que yo esta consulta la he probado (y funciona) en Firebird.
Interbase hace mucho tiempo que deje de usarlo.


La franja horaria es GMT +2. Ahora son las 22:17:07.

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