Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 17-05-2003
judoboy judoboy is offline
Miembro
 
Registrado: may 2003
Ubicación: Valencia
Posts: 139
Poder: 21
judoboy Va por buen camino
Conocer el número de registros

Hola tengo que necesito realizar una consulta para saber cuantas veces aparece un campo en una tabla.

Ej. quiero saber cuantas veces aparace un socio, y para ello hago lo siguiente pero falla:
Código:
SELECT COUNT(CP.SOCIO) FROM COPIAS_PELICULA CP, SOCIO S
WHER S.CODIGO_SOCIO=CP.SOCIO AND
S.CODIGO_SOCIO='''+codigouser+''' ';
hay alguna otra forma de hacerlo
Responder Con Cita
  #2  
Antiguo 17-05-2003
judoboy judoboy is offline
Miembro
 
Registrado: may 2003
Ubicación: Valencia
Posts: 139
Poder: 21
judoboy Va por buen camino
Se me olvidaba utilizo Acces, en esta aplicación.

Responder Con Cita
  #3  
Antiguo 17-05-2003
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
SELECT COUNT(CP.SOCIO) FROM COPIAS_PELICULA CP
where CP.CODIGO_SOCIO='''+codigouser+''' ';

Si el código del Socio está en las 2 tablas, no nos hace falta para nada la tabla de Socios, puesto que de lo que se trata de saber es cuantas veces está este socio en la Tabla Copias_Pelicula.

Un Saludo.
Responder Con Cita
  #4  
Antiguo 17-05-2003
andres1569 andres1569 is offline
Miembro
 
Registrado: may 2003
Posts: 908
Poder: 21
andres1569 Va por buen camino
Hola:

Judoboy escribió:

Código:
SELECT COUNT(CP.SOCIO) FROM COPIAS_PELICULA CP, SOCIO S
WHER S.CODIGO_SOCIO=CP.SOCIO AND
S.CODIGO_SOCIO='''+codigouser+''' ';
Hay dos cosas que quizás sean errores de redacción (WHER es WHERE), y a '''codigouser + ''' '; le falta una comilla al principio, y le sobra el espacio final, no sé si lo tienes igual en la consulta.

Otra cosa: no hace falta que ligues con la tabla SOCIO, bastaría lo siguiente:

Código:
SELECT COUNT(CP.SOCIO)
FROM COPIAS_PELICULA CP
WHER CP.SOCIO=''''+codigouser+'''';
Creo que éste código debería funcionar

Saludos
Responder Con Cita
  #5  
Antiguo 17-05-2003
judoboy judoboy is offline
Miembro
 
Registrado: may 2003
Ubicación: Valencia
Posts: 139
Poder: 21
judoboy Va por buen camino
Bueno, es que he probado de la forma que me me comentais y tambien fallaba, por eso pensaba si tenia que relacionar las tablas.
Lo de WHER ha sido un fallo en la transcripción y lo de la comilla que falta es por que falta la del principio que se me habia olvidado ponerla:

'SELECT .....

de todas formas, el fallo que me dice es que los tipos no coinciden, utilizo el debugger, para ver el valor que tiene codigouser y tiene '1' y SOCIO es de tipo número en Acces.

Donde puede estar el error.

Hay donde este Interbase&Firebird que se quite el p*** Access
Responder Con Cita
  #6  
Antiguo 17-05-2003
andres1569 andres1569 is offline
Miembro
 
Registrado: may 2003
Posts: 908
Poder: 21
andres1569 Va por buen camino
Hola:

Pues por lo que dices el error está en poner el codigouser entre comillas, puesto que no es un valor tipo cadena.

Saludos
Responder Con Cita
  #7  
Antiguo 17-05-2003
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Prueba con este ejemplo y verás como te funciona:

procedure TForm1.Button1Click(Sender: TObject);
var
CodigoUser:Integer;
begin
CodigoUser:=1;

ADO_Q.Close;
ADO_Q.Sql.Clear;
ADO_Q.Sql.Add('Select Count(Cp) from Copias_Pelicula');
ADO_Q.Sql.Add('Where CP ='+IntToSTr(CodigoUser));
ADO_Q.Active:=True;

end;

Un Saludo.
Responder Con Cita
  #8  
Antiguo 19-05-2003
judoboy judoboy is offline
Miembro
 
Registrado: may 2003
Ubicación: Valencia
Posts: 139
Poder: 21
judoboy Va por buen camino
Muchas gracias, ya me funciona, menos mal.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 18:25:02.


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
Copyright 1996-2007 Club Delphi