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 12-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
Consulta Sql con query

Hola

Tengo un problema . tengo una base de datos en access con una tabla, intento aser una query des de codico delphi.
EL codigo:

Código Delphi [-]
procedure TForm1.Button1Click(Sender: TObject);
begin
query1.Close;
query1.SQL.Clear;
query1.SQL.add('select * from project where city=:param');
query1.ParamByName('param').AsString:=combobox1.Text;
//query1.Prepare;
//query1.Active:=true;
query1.ExecSQL;
query1.active:=true;
dbgrid1.Refresh;
end;

el query le paso un param que coje un val de un combobox. El problema es que no se por que no funciona y tampoco me inseña el rezultado en un dbgrid.

Me podeis echar una mano porfa , me vuelvo loco.

Última edición por ContraVeneno fecha: 12-01-2011 a las 17:22:51. Razón: /delphi a [/delphi], se deben usar corchetes para los bloques
Responder Con Cita
  #2  
Antiguo 12-01-2011
Avatar de microbiano
microbiano microbiano is offline
Miembro
 
Registrado: sep 2008
Ubicación: Mexico D.F
Posts: 349
Poder: 16
microbiano Va por buen camino
que tal si cambias el query1. execSQl por Query1.open;


normalmente exec es para cuando quieres hacer una instruccion de insertar,modificar o eliminar, para consultas usa open.

saludos, por cierto usa las etiquetas delphi para que tu codigo se vea mejor.

Última edición por microbiano fecha: 12-01-2011 a las 17:06:55. Razón: complemento
Responder Con Cita
  #3  
Antiguo 12-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
Cita:
Empezado por microbiano Ver Mensaje
que tal si cambias el query1. execSQl por Query1.open;


normalmente exec es para cuando quieres hacer una instruccion de insertar,modificar o eliminar, para consultas usa open.

saludos, por cierto usa las etiquetas delphi para que tu codigo se vea mejor.
Por desgracia sigue igual.
El programa no devuelve ningun error el problema que tengo es que el param puede tener 2 val : a y b , que seguro se encuentran en la base de datos.
si le escrivo el texto a mano "select ..... city='a' " directamente en el query pues funciona. si lo intento usar con param no .
Responder Con Cita
  #4  
Antiguo 12-01-2011
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
Código Delphi [-]
procedure TForm1.Button1Click(Sender: TObject);
begin
 with query1 do begin
  Close;
  SQL.Clear;
  SQL.add('select Campos');
  SQL.Add('from project');
  SQL.Add('where city=:param');
  ParamByName('param').AsString:=combobox1.Text;
  Open;
  dbgrid1.Refresh;
 end; //with
end;

eso debe de funionar, si no funciona, es porque combobox1.text no te está dando el valor que tu quieres... ¿no será que debes usar ItemIndex en lugar de Text para tomar el valor?

Además, lo que pongas en tu Combo debe de ser exactamente igual a lo que tengas en tu case de datos, en este caso, creo que sería mejor un LookUpComboBox...
__________________

Responder Con Cita
  #5  
Antiguo 12-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
Cita:
Empezado por ContraVeneno Ver Mensaje
Código Delphi [-]procedure TForm1.Button1Click(Sender: TObject); begin with query1 do begin Close; SQL.Clear; SQL.add('select Campos'); SQL.Add('from project'); SQL.Add('where city=:param'); ParamByName('param').AsString:=combobox1.Text; Open; dbgrid1.Refresh; end; //with end;


eso debe de funionar, si no funciona, es porque combobox1.text no te está dando el valor que tu quieres... ¿no será que debes usar ItemIndex en lugar de Text para tomar el valor?

Además, lo que pongas en tu Combo debe de ser exactamente igual a lo que tengas en tu case de datos, en este caso, creo que sería mejor un LookUpComboBox...

Gracias funciona por que no me da ningun error. Pero sigue sin ponerme los rezultados en el dbgrid.
Y no intiendo por que.
Responder Con Cita
  #6  
Antiguo 12-01-2011
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.288
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Prueba la misma consulta pero sin el WHERE.
¿Salen datos ahora?

Si es que sí, intenta comprobar lo que estás pasando como parámetro. Si es que no, debe ser por otra cosa. Revisa que tengas creadas las columnas en el Grid y vuelve a crearlas.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #7  
Antiguo 13-01-2011
Avatar de microbiano
microbiano microbiano is offline
Miembro
 
Registrado: sep 2008
Ubicación: Mexico D.F
Posts: 349
Poder: 16
microbiano Va por buen camino
por curiosidad tienes enlazado el DGbrid a un DataSource y este al Query?, digo si no es asi como quieres hacerlo?
Responder Con Cita
  #8  
Antiguo 13-01-2011
Avatar de Chris
[Chris] Chris is offline
Miembro Premium
 
Registrado: abr 2007
Ubicación: Jinotepe, Nicaragua
Posts: 1.678
Poder: 19
Chris Va por buen camino
Otra sugerencia, cerciórate de la capitalización de las letras. Muchas veces nos dan dolores de cabeza joyitas como estas.

Saludos,
Chris
__________________
Perfil Github - @chrramirez - Delphi Blog - Blog Web
Responder Con Cita
  #9  
Antiguo 13-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
Cita:
Empezado por Chris Ver Mensaje
Otra sugerencia, cerciórate de la capitalización de las letras. Muchas veces nos dan dolores de cabeza joyitas como estas.

Saludos,
Chris
Si estube atento a las letras. No es por A or a en las palabras que uso para la busqeda.

Cita:
por curiosidad tienes enlazado el DGbrid a un DataSource y este al Query?, digo si no es asi como quieres hacerlo?
Claro que si
Tengo

Tdatabase
Tdatasource
tDbgrid
tquery

datasource apunta al query
dbgrid apunta al datasource
Responder Con Cita
  #10  
Antiguo 13-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
Cita:
Empezado por Neftali Ver Mensaje
Prueba la misma consulta pero sin el WHERE.
¿Salen datos ahora?

Si es que sí, intenta comprobar lo que estás pasando como parámetro. Si es que no, debe ser por otra cosa. Revisa que tengas creadas las columnas en el Grid y vuelve a crearlas.
sigue sin funcionar da egual que con o sin with
Por que hay que crearlas a mano ? se sopone que cuando activo el query tendria que activarse la conexion con el dbgrid y crear de forma automatica las columnas.
DE toda forma esta creando de forma automatica las columnas de la tabla pero lo que no hase es popular el dbgrid con los valores.

El parametro esta conf como string y imput .
Me entra unas ganas de llevar a patadas el pc . Esto es algo simple pero no intiendo por que no funciona.
Responder Con Cita
  #11  
Antiguo 13-01-2011
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.288
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Otra opción es que subas un pequeño proyecto de ejemplo (puedes crear un proyecto con un formulario similar al que tienes) y con unos datos de ejemplo y le echamos un vistazo. Estoy convencido de que debe ser una tontería, pero sin ver más es difícil saber qué puede estar pasando.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #12  
Antiguo 13-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
Cita:
Empezado por Neftali Ver Mensaje
Otra opción es que subas un pequeño proyecto de ejemplo (puedes crear un proyecto con un formulario similar al que tienes) y con unos datos de ejemplo y le echamos un vistazo. Estoy convencido de que debe ser una tontería, pero sin ver más es difícil saber qué puede estar pasando.
Aqui esta puesto el project con la db de test.
es una db de access y utilizo delphi 2010.
si necesitas mas info ....
no lo puedo subir por el tamaño.
el link para mis doc´s :
https://docs.google.com/leaf?id=0B6w...thkey=CPK-7u4P
Gracias por la ayuda.
Responder Con Cita
  #13  
Antiguo 13-01-2011
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.288
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Pues he probado el ejemplillo que has enviado, tanto con BDE como cambiando los componentes por los ADO y utilizando este código y me funciona perfectamente. Cuando selecciono "Alzira" me aparece 1, cuando es "Madrid" me aparecen 5:

Código Delphi [-]
  // con BDE
 with Query1 do begin
  Close;
  SQL.Clear;
  SQL.add('select *');
  SQL.Add('from project');
  SQL.Add('where city=: param');
  ParamByName('param').AsString:=combobox1.Text;
  Open;
  dbgrid1.Refresh;
 end; //with
end;

Código Delphi [-]
 // Con ADO
 with ADOQuery1 do begin
  Close;
  SQL.Clear;
  SQL.add('select *');
  SQL.Add('from project');
  SQL.Add('where city=: param');
  Parameters.FindParam('param').Value := combobox1.Text;
  Open;
  dbgrid1.Refresh;
 end; //with
end;

NOTA: los espacios en el : param están porque si no aparece esto aram

¿Cuando lo ejecutas tú, te da algun error?
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #14  
Antiguo 13-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
no da error solo no esta populando el dbgrid

si le pongo ": param" con espacio ente : y param me da error parametro param desconocido si lo pongo sin espacio no da error
Responder Con Cita
  #15  
Antiguo 13-01-2011
Avatar de microbiano
microbiano microbiano is offline
Miembro
 
Registrado: sep 2008
Ubicación: Mexico D.F
Posts: 349
Poder: 16
microbiano Va por buen camino
prueba asi

Código Delphi [-]
with self.query1 do begin
  Close;
  SQL.Clear;
  SQL.add('select *');
  SQL.Add('from project');
  SQL.Add('where city=aram'); //recuerda que tiene saler la carita pero realmente es el nombre del parametro
  parameters.ParamByName('param').value:=combobox1.Text;//aqui cambie As String por value
  try
    open;     
   except
    on E:EOleException do
     begin
      MessageDlg(Format('Error: %s    Codigo: %d', [E.Message, E.ErrorCode]), mtError, [mbOK], 0);
     end;
   end;

 end; //with
end;


Debes tener declara la libreria ComObjs para que funcione.

Última edición por microbiano fecha: 13-01-2011 a las 16:39:43. Razón: modificar texto
Responder Con Cita
  #16  
Antiguo 13-01-2011
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.288
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por bogdanioanliviu Ver Mensaje
no da error solo no esta populando el dbgrid

si le pongo ": param" con espacio ente : y param me da error parametro param desconocido si lo pongo sin espacio no da error
No me refería a ponerlo en Delphi con el espacio, me refería a ponerlo en los foros con el espacio.

¿Has probado a realizar la conexión con ADO? Para descartar que sea algo de BDE.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #17  
Antiguo 13-01-2011
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.288
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por microbiano Ver Mensaje
Debes tener declara la libreria ComBojs para que funcione.
El problema es que no le da error, por lo tanto la excepción la captura de la excepción no hará nada.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #18  
Antiguo 13-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
Cita:
Empezado por Neftali Ver Mensaje
No me refería a ponerlo en Delphi con el espacio, me refería a ponerlo en los foros con el espacio.

¿Has probado a realizar la conexión con ADO? Para descartar que sea algo de BDE.
no lo he probado pero si tengo que cambiar ahora a ADO me muero. Asi que no es una opcion.
Responder Con Cita
  #19  
Antiguo 13-01-2011
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.288
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por bogdanioanliviu Ver Mensaje
no lo he probado pero si tengo que cambiar ahora a ADO me muero. Asi que no es una opcion.
Me refería a que lo cambiaras en el ejemplo para probar y descartar cosas; Saber si funciona con ADO y con el BDE no o algo así.
Como ya te he dicho, a mi me ha funcionado el ejemplo con ambos (Delphi 6).
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #20  
Antiguo 13-01-2011
bogdanioanliviu bogdanioanliviu is offline
Miembro
 
Registrado: sep 2010
Posts: 17
Poder: 0
bogdanioanliviu Va por buen camino
Cita:
Empezado por Neftali Ver Mensaje
Me refería a que lo cambiaras en el ejemplo para probar y descartar cosas; Saber si funciona con ADO y con el BDE no o algo así.
Como ya te he dicho, a mi me ha funcionado el ejemplo con ambos (Delphi 6).
ME voy a ca... en todo . Ya esta funcionando corectamente.
La solucion corecta adjudecada al usuario microbiano. Gracias por tu alliuda .
Gracias a todos por vuestra alluda y colaboracion.

El problema era que que yo tenia .asstring y tendria que ser como .value
Gracias.
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
hacer consulta en un query Carlos León Conexión con bases de datos 2 22-09-2008 10:06:51
consulta a un query en vez de a una tabla eldiegofg SQL 10 19-09-2007 12:46:39
Consulta de Query marceloalegre SQL 3 06-02-2006 16:38:37
Tengo una consulta en un query ElDioni SQL 3 12-07-2005 11:41:34
Consulta con una variable en un Query Ricsato SQL 3 25-11-2003 22:47:37


La franja horaria es GMT +2. Ahora son las 21:40:01.


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