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 - Trabajar con nulos (null) en campos de BD
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Trabajar con nulos (null) en campos de BD

Publicar nuevo tema Responder al tema
Foros de discusión » VB.Net, C# .Net, Visual Studio .Net   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Trabajar con nulos (null) en campos de BD Responder citando

Tengo una aplicación realizada en Visual Basic 6, tengo un código que accede a una base de datos Oracle. Me funciona correctamente salvo cuando el valor de los registros que necesito extraer es nulo (cuando no tiene nada) ¿cómo puedo hacer una comprobación previa para saber si el valor de un campo es nulo sin que me dé error?

El código que utilizo es:

Código:

  ...
  Set rsConsulta = rdoConexion.OpenResultset(filtro, rdOpenStatic)
  If rsConsulta.RowCount = 1 Then
    txtReferencia.Value = rsConsulta.rdoColumns("REFERENCIA").Value
    txtImporte.Value = rsConsulta.rdoColumns("IMPORTE").Value
  ...
MensajePublicado:
Mie Dic 19, 2007 8:05 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Trabajar con nullos (null) en campos de BD Responder citando



Anuncios



varios escribió:
Tengo una aplicación realizada en Visual Basic 6, tengo un código que accede a una base de datos Oracle. Me funciona correctamente salvo cuando el valor de los reg...


Para saber si una variable es nula puedes utilizar la función "VarType" de Visual Basic, que devolverá los siguientes valores:

vbEmpty 0 Empty (no inicializado)
vbNull 1 Null (datos no válidos)
vbInteger 2 Entero
vbLong 3 Entero largo
vbSingle 4 Un número de coma flotante de precisión simple
vbDouble 5 Un número de coma flotante de precisión doble
vbCurrency 6 Valor de moneda
vbDate 7 Valor de fecha
vbString 8 Cadena
vbObject 9 Objeto
vbError 10 Valor de error
vbBoolean 11 Valor booleano
vbVariant 12 Variant (utilizada solamente conmatrices de variantes)
vbDataObject 13 Un objeto de acceso a datos
vbDecimal 14 Valor decimal
vbByte 17 Valor de byte
vbUserDefinedType 36 Tipos definidos por el usuario
vbArray 8192 Matriz


Aplicando esta función a tu código quedaría algo así:

Código:

  ...
  Set rsConsulta = rdoConexion.OpenResultset(filtro, rdOpenStatic)
  If rsConsulta.RowCount = 1 Then
    If VarType(rsConsulta.rdoColumns("REFERENCIA").Value) <> vbNull Then
      txtReferencia.Value = rsConsulta.rdoColumns("REFERENCIA").Value
    end if
    If VarType(rsConsulta.rdoColumns("IMPORTE").Value) <> vbNull Then
      txtImporte.Value = rsConsulta.rdoColumns("IMPORTE").Value
    end if
    ...
MensajePublicado:
Mie Dic 19, 2007 9:09 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 » VB.Net, C# .Net, Visual Studio .Net  

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