Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > OOP
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-01-2011
Avatar de DarkBlue
DarkBlue DarkBlue is offline
Miembro
 
Registrado: jun 2010
Posts: 105
Poder: 14
DarkBlue Va por buen camino
erro con campos vacios en el dbgrid

hola amigos me encuentro en un problema que pienso que es muy sencillo sin embargo no se me ocurre como resolverlo apuesto que con su amplia experiencia sera resuelto en un segundo.


lo que pasa es que lleno un dbgrid con una consulta , hasta ahi todo bien lo que es un problema es que cuando el campo tiene un valor en blanco o como decirlo no tiene escrito nada,despues de darle el doble click me manda un mensaje de error como el que sigue:



proyect raised exception class EAccessViolation with message 'Access violation at address 00569023 in module 'lala.exe' . Read of address 00000000'. Process stopped. Use step or run to continue

este es el codigo del evento DBGrid2DblClick

Código:
claveservicio:=dbgrid2.Fields[1].asstring;
¿como puedo evitar este error? . La verdad solo quiero saber si contiene algun valor el campo o no , intente con la funcion varisnull y length para saber si tiene o no un valor ese campo
__________________
Todo es Relativo
Responder Con Cita
  #2  
Antiguo 12-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
Realmente desconocía que se podía acceder a los valores de esa forma que pones. Te recomiendo que para acceder a los valores de un registro es mejor que utilices el componente de acceso a datos y lo hagas referenciando el nombre del campo, no con el número del campo en el arreglo. Esto te ayudará a hacer un código más sólido.

Código Delphi [-]
claveservicio:= MiQuery.FieldByName('clave_servicio').asstring;

Saludos,
Chris
__________________
Perfil Github - @chrramirez - Delphi Blog - Blog Web
Responder Con Cita
  #3  
Antiguo 12-01-2011
Avatar de Aleca
Aleca Aleca is offline
Miembro
 
Registrado: may 2003
Ubicación: Venado Tuerto, Argentina
Posts: 277
Poder: 21
Aleca Va por buen camino
coincido con chris nunca lo habia usado de esa forma, a veces lo hice de esta forma
Código Delphi [-]
  Grilla.SelectedField.AsString
Saludos
__________________
Aleca
Responder Con Cita
  #4  
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.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
Posiblemente puedas evitarlo también preguntando si el campo al que estás intentando acceder está o no asignado:

Código Delphi [-]
if Assigned(dbgrid2.Fields[1]) then begin
  claveservicio:=dbgrid2.Fields[1].asstring;
end
else begin
  claveservicio:='';
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
  #5  
Antiguo 12-01-2011
Avatar de DarkBlue
DarkBlue DarkBlue is offline
Miembro
 
Registrado: jun 2010
Posts: 105
Poder: 14
DarkBlue Va por buen camino
Es que ese no es el caso tengo que mostrar todos los resultados en el grid(por que no solo es un resultado de la consulta son muchas filas) y que desde ahí seleccione el dato dándole doble clic.


He solucionado parcialmente el problema dándole un valor al resultado que no lo tiene. Pero aun así necesito resolver ese problema
__________________
Todo es Relativo
Responder Con Cita
  #6  
Antiguo 12-01-2011
Avatar de DarkBlue
DarkBlue DarkBlue is offline
Miembro
 
Registrado: jun 2010
Posts: 105
Poder: 14
DarkBlue Va por buen camino
Muchas gracias neftali sabia que no me podías fallar siempre con una respuesta acertada es justo lo que necesitaba. Posté antes de recargar muchas gracias.
__________________
Todo es Relativo
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
Comprobar campos vacios o con espacios... Greco Varios 4 21-09-2007 03:57:11
crear mensaje para guardar con campos vacios formularios redimido OOP 1 06-08-2007 20:31:12
DateTime con vacios CamiloU OOP 4 12-01-2006 12:37:34
no ingresar vacios o nulos.. pzala Varios 5 30-08-2005 21:40:02
consultar campos vacios noe SQL 1 21-03-2005 17:35:42


La franja horaria es GMT +2. Ahora son las 03:59:13.


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