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: 24
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.309
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
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 22:40:41.


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