Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Error EZSQLException AjpdSoft Comprobar E-Mail y AntiSpam
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error EZSQLException AjpdSoft Comprobar E-Mail y AntiSpam

Publicar nuevo tema Responder al tema
Foros de discusión » Programas Proyecto AjpdSoft   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Error EZSQLException AjpdSoft Comprobar E-Mail y AntiSpam Responder citando

Estoy utilizando AjpdSoft Comprobar E-Mail y AntiSpam, y en algunas cuentas de email de las que compruebo el spam me aparece este error:

---------------------------
Debugger Exception Notification
---------------------------
Project cemail.exe raised exception class EZSQLException with message 'SQL Error: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'Citizen Kane" still No.1 movie-"Godfather" 2nd" AND TIPO = "ASUNTO"' at line 1'. Process stopped. Use Step or Run to continue.
---------------------------
OK Help
---------------------------


Creo que ocurre cuando el asunto del email emisor tiene símbolos como comillas dobles.
MensajePublicado:
Vie Jul 20, 2007 8:23 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error EZSQLException AjpdSoft Comprobar E-Mail y AntiSpa Responder citando



Anuncios



varios escribió:
Estoy utilizando AjpdSoft Comprobar E-Mail y AntiSpam, y en algunas cuentas de email de las que compruebo el spam me aparece este error:

---------------------------
Debugger Exception Notification
---------------------------
Project cemail.exe raised exception class EZSQLException with message 'SQL Error: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'Citizen Kane" still No.1 movie-"Godfather" 2nd" AND TIPO = "ASUNTO"' at line 1'. Process stopped. Use Step or Run to continue.
---------------------------
OK Help
---------------------------


Creo que ocurre cuando el asunto del email emisor tiene símbolos como comillas dobles.



Hemos reproducido el error que nos comentas y hemos depurado y localizado el problema. Efectivamente se trataba de un problema a la hora de pasar la consulta SQL al objeto TZQuery. El problema estaba en este código:

Código:

  tConsulta.Close;
  tConsulta.SQL.Clear;
  tConsulta.SQL.Add('SELECT ID FROM criteriosspam ' +
      'WHERE DATO = "' + varDato + '"');
  tConsulta.SQL.Add('AND TIPO = "' + vatTipo + '"');
  try
    tConsulta.Open;
  except
    raise;
  end;


El problema está en la forma de pasarle los datos a la consulta SQL, al pasárselos con una variable de tipo string (varDato) y tener que ponerla entre comillas dobles, si la variable varDato lleva comillas dobles también la consulta SQL dará error.

Para solucionar este problema, es suficiente con utilizar parámetros en vez de variables concatenadas. El código delphi arreglado será algo así:

Código:

  tConsulta.Close;
  tConsulta.SQL.Clear;
  tConsulta.SQL.Add('SELECT ID FROM criteriosspam ' +
       'WHERE DATO = :pDato');
  tConsulta.SQL.Add('AND TIPO = :pTipo');
  tConsulta.ParamByName('pDato').DataType := ftString;
  tConsulta.ParamByName('pDato').Value := dato;
  tConsulta.ParamByName('pTipo').DataType := ftString;
  tConsulta.ParamByName('pTipo').Value := tipo;
  try
    tConsulta.Open;
  except
    raise;
  end;



De esta forma será Delphi el que se encarge de formatear la cadena adecuadamente según el motor de base de datos, en este caso, si el parámetro lleva comillas dobles colocará \".

En breve colocaremos la nueva versión de la aplicación en esta página web, en el enlace:

http://www.ajpdsoft.com/modules.php?name=Downloads&d_op=viewdownloaddetails&lid=63
MensajePublicado:
Vie Jul 20, 2007 8:36 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Programas Proyecto AjpdSoft  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A