FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
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? |
#2
|
||||
|
||||
La consulta como está creo que no tiene mucho sentido... creo que así estaría bien:
__________________
...y mañana caminaré por las calles pasando inadvertido, como siempre. |
#3
|
|||
|
|||
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 |
#4
|
|||
|
|||
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. |
#5
|
||||
|
||||
FireBird 2.0 sí permite hacer la consulta:
InterBase 7.5 no lo permite. Acabo de probarlo en ambos.
__________________
...y mañana caminaré por las calles pasando inadvertido, como siempre. |
#6
|
|||
|
|||
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
|
#7
|
||||
|
||||
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).
Saludos |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
error "Subquery returned more than 1 value" | lynu | SQL | 1 | 14-08-2006 16:16:25 |
SubQuery con error?? | danytorres | SQL | 2 | 24-01-2005 19:12:06 |
(DBE+.dbf+subquery) Como hago un (capo1,campo2) IN (Select campo1,campo2, FR...) | orfeo | SQL | 12 | 31-03-2004 23:53:05 |
|