Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > MySQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 24-03-2004
WaRRanT WaRRanT is offline
Miembro
 
Registrado: feb 2004
Posts: 33
Poder: 0
WaRRanT Va por buen camino
TRaduzir Key Violation ZEOS

Ola amigos,


Alguém sabe como traduzir "Key Violation" no ZEOS?

Gracias,

WaRRanT

Abraços a todos!
Responder Con Cita
  #2  
Antiguo 24-03-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola.

Un Key Violation no es un error propio de un determinado componente. Usualmente se da por intentar utilizar propiedades o métodos de una instancia inexistente de un objeto. Ya sea porqué esa instancia aún no ha sido creada, ya ha sido liberada, etc. ...

Tienes que seguir el código con el debugger, y en la linea que da el error, comprobar que problema puede tener el objeto en el que falla la llamada.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #3  
Antiguo 24-03-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por guillotmarc
Un Key Violation no es un error propio de un determinado componente. Usualmente se da por intentar utilizar propiedades o métodos de una instancia inexistente de un objeto.
Marc, me parece que te confundiste entre Access Violation y Key Violation. Esto suele pasar

Un saludo
Responder Con Cita
  #4  
Antiguo 24-03-2004
WaRRanT WaRRanT is offline
Miembro
 
Registrado: feb 2004
Posts: 33
Poder: 0
WaRRanT Va por buen camino
"SQL Error: Duplicate entry '11111111' for key 1."

Isso não é equivalente ao "KEY VIOLATION"?

Não tem como eu tratar este erro?

Gracias,

WaRRanT

Abraços!
Responder Con Cita
  #5  
Antiguo 24-03-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Jejeje, tienes toda la razón Román (que verguenza, vaya lapsus)

En efecto WaRRanT, ese error es un KEY VIOLATION. ¿ No lo puedes capturar en un try .. except ?. Aunque desconozco como se accede a la información del Error en las Zeos.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #6  
Antiguo 24-03-2004
WaRRanT WaRRanT is offline
Miembro
 
Registrado: feb 2004
Posts: 33
Poder: 0
WaRRanT Va por buen camino
Post

Eu fiz da seguinte maneira:


procedure TFrmConfSimples.QyMovValesBeforePost(DataSet: TDataSet);
begin
QyPesqVales.Active := False;
QyPesqVales.SQL.Clear;
QyPesqVales.SQL.Add('Select * from MovVales Where Numero = "'+DbEdit3.Text+'"');
QyPesqVales.Active := True;
QyPesqVales.ExecSQL;
If not QyPesqVales.Eof then
begin
Sound(3000,1000);
MessageDlg('Este Vale já existe!'+#13+'Favor Conferir o Vale '+#13+' nº '+FrmConfSimples.Dbedit3.text,
MtError,[Mbok],0);
Abort;
Dbedit3.SetFocus;
Dbedit3.Clear;
end;
end;

end.




Mas acontece que existindo ou não o registro, o EOF sempre aparece TRUE.....
Responder Con Cita
  #7  
Antiguo 24-03-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Mira a ver si tienes disponible la propiedad IsEmpty.

Código:
If not QyPesqVales.IsEmpty then
Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #8  
Antiguo 24-03-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
No uses ExecSql para consultas SELECT. Por otra parte creo qe simplemente puedes usar QyPesqVales.RecordCount para saber si la consulta regresó o n o resultados.

// Saludos
Responder Con Cita
  #9  
Antiguo 24-03-2004
WaRRanT WaRRanT is offline
Miembro
 
Registrado: feb 2004
Posts: 33
Poder: 0
WaRRanT Va por buen camino
Gracias amigos!

Mas o EOF não teria tambiem que funcionar neste caso?

Abraços!
Responder Con Cita
  #10  
Antiguo 25-03-2004
WaRRanT WaRRanT is offline
Miembro
 
Registrado: feb 2004
Posts: 33
Poder: 0
WaRRanT Va por buen camino
Roman,

Gracias! O problema era mesmo o EXECSQL...

Abraços!
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:13:11.


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