Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 12-10-2020
serhasae serhasae is offline
Miembro
 
Registrado: jun 2004
Ubicación: España
Posts: 117
Poder: 20
serhasae Va por buen camino
AdoQuery y Parametros

Código Delphi [-]
ATasm.Active:=False;

ATasm.SQL.Clear;

ATasm.SQL.Text:='SELECT T.PMAX, T.PRECIO '+
                'FROM TASM AS T '+
                'WHERE T.AGENCIA=:AG AND T.DESTINO=:XS AND (:ES>=T.EMIN AND :ES<=T.EMAX);';


ATasm.Parameters.ParamByName('AG').Value:='ASMMAS';
ATasm.Parameters.ParamByName('XS').Value:='NAP';
ATasm.Parameters.ParamByName('ES').Value:=180.4;

ATasm.Prepared:=True;

ATasm.Active:=True;


Me dice que no encuentra el parametro ES.
He probado a dejarlo sin los parentesis y sigue dando error, los parametros son 2 de tipo string y 1 de tipo float.


Me estoy volviendo loco, a ver si alguien me explica en que estoy fallando, Saludos Marcos si sigues por aqui.

Gracias.

Sergio.

Última edición por serhasae fecha: 12-10-2020 a las 03:04:07.
Responder Con Cita
  #2  
Antiguo 12-10-2020
serhasae serhasae is offline
Miembro
 
Registrado: jun 2004
Ubicación: España
Posts: 117
Poder: 20
serhasae Va por buen camino
Lo he solucionado cambiando los parametros por variables y pasandolo todo como texto, pero no entiendo como solucionar este error con los parametros y porque sucede.
Responder Con Cita
  #3  
Antiguo 12-10-2020
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
No uso ADO, pero por probar:
Código Delphi [-]
ATasm.Close;
ATasm.SQL.Text:='SELECT T.PMAX, T.PRECIO '+
                'FROM TASM AS T '+
                'WHERE T.AGENCIA=:AG AND T.DESTINO=:XS AND (:ES>=T.EMIN AND :EZ<=T.EMAX);';
ATasm.Parameters.ParamByName('AG').Value:='ASMMAS';
ATasm.Parameters.ParamByName('XS').Value:='NAP';
ATasm.Parameters.ParamByName('ES').Value:=180.4;
ATasm.Parameters.ParamByName('EZ').Value:=180.4;
ATasm.Open;
Responder Con Cita
  #4  
Antiguo 12-10-2020
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola a todos,

No soy un experto en el tema, pero, ¿tal vez habría que cambiar el orden de los parámetros? Es decir, en lugar de esto:

Código SQL [-]
(:ES >= T.EMIN AND :ES <= T.EMAX)

... usar esto otro:

Código SQL [-]
(T.EMIN <= :ES AND T.EMAX >= :ES)
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #5  
Antiguo 12-10-2020
Avatar de fjcg02
[fjcg02] fjcg02 is offline
Miembro Premium
 
Registrado: dic 2003
Ubicación: Zamudio
Posts: 1.410
Poder: 22
fjcg02 Va camino a la fama
Si no estoy equivocado, no se puede utilizar dos veces el mismo parametro.

Si le cambias el nombre y le asignas el mismo valor, seguramenta funcionará.


Saludos
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino -
Responder Con Cita
  #6  
Antiguo 12-10-2020
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por fjcg02 Ver Mensaje
Si no estoy equivocado, no se puede utilizar dos veces el mismo parametro.
Si le cambias el nombre y le asignas el mismo valor, seguramenta funcionará.
Saludos
Justo lo que he indicado, seguro que es eso.
Responder Con Cita
  #7  
Antiguo 12-10-2020
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola a todos,

Cita:
Empezado por Casimiro Notevi Ver Mensaje
Justo lo que he indicado, seguro que es eso.
De ahí que añadiese el parámetro "EZ"... digo, "este hombre, que hace..."... y resulta que estabas acaso dando en el clavo.

Tal vez sea entonces eso, en efecto. No le encuentro mucho sentido a tener que indicar diferentes argumentos... al fin y al cabo se trata de "cambiar el parámetro por el valor correspondiente", y, no veo ahí porqué hay que tener diferentes parámetros para los mismos valores...

Claro que tampoco encuentro mucho sentido a lo que yo he propuesto... cambiar el orden de los parámetros... tal vez que estoy acostumbrado a dicho orden, y, el otro me ha llamado la atención, pero, como digo, tampoco vería mucho sentido a una obligación así.

En fin, vamos a ver al final en qué queda todo.
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #8  
Antiguo 13-10-2020
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.275
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
Creo que aquí hay varios problemas. Algunos ya se han comentado

1) Los parámetros son para valores de la consulta, no para los nombres de campos. Por eso:

Código SQL [-]
(:ES >= T.EMIN AND :ES <= T.EMAX)
Esto te está fallando por el parámetro ES.

Para esto sólo te queda utilizar variables para los nombres de campo (tal como has comentado).
Pero yo seguiría utilizando los parámetros para los valores. Ya que esto tiene muchas ventajas.

2) Por otro lado tienes 2 veces el mismo parámetro. ES
Como han comentado la opción es cambiar los nombres de los parámetros o también se puede utilizar un bucle FOR para todos los parámetros iguales. Eso te permitiría una solución más genérica.

Puedes hacer algo como esto:
Código Delphi [-]

var
  p:TParameters;
  i: Integer;
begin
      ...  

      p := TADOQuery(aDataset).Parameters;
      for i := 0 to (p.Count - 1) do begin
        if (AnsiCompareText(p[i].Name, 'SE') = 0) then
          p[i].Value := aCodigo;
      end;
__________________
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
  #9  
Antiguo 22-10-2020
serhasae serhasae is offline
Miembro
 
Registrado: jun 2004
Ubicación: España
Posts: 117
Poder: 20
serhasae Va por buen camino
Gracias lo pruebo y os comento. Saludos.
Responder Con Cita
  #10  
Antiguo 22-10-2020
serhasae serhasae is offline
Miembro
 
Registrado: jun 2004
Ubicación: España
Posts: 117
Poder: 20
serhasae Va por buen camino
Nunca hubiera pensado que el orden importa. Gracias Dec era eso. Solución:

Código Delphi [-]
ATasm.Close;
ATasm.SQL.Text:='SELECT T.PMAX, T.PRECIO '+
                'FROM TASM AS T '+
                'WHERE T.AGENCIA=:AG AND T.DESTINO=:XS AND (T.EMIN <= :ES AND T.EMAX >= :ES);';
ATasm.Parameters.ParamByName('AG').Value:='ASMMAS';
ATasm.Parameters.ParamByName('XS').Value:='NAP';
ATasm.Parameters.ParamByName('ES').Value:=180.4;

ATasm.Open;

Gracias a todos.
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
problemas con parametros en adoquery elsamurai Impresión 6 20-12-2010 06:39:00
ADOQuery: like con parámetros Gaim2205 SQL 1 07-10-2008 16:38:45
Problemas con AdoQuery / Parametros mateamargo SQL 4 18-04-2008 20:50:55
Adoquery con parametros erasmorc OOP 2 16-03-2007 14:29:15
Pasar parametros a ADOQUERY JODELSA Conexión con bases de datos 1 04-09-2003 23:47:36


La franja horaria es GMT +2. Ahora son las 20:22:14.


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