vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
vb@rchiv Offline-Reader - exklusiv auf der vb@rchiv CD Vol.4  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
Fehlermeldung Cellformatting 
Autor: Knabber
Datum: 02.03.19 10:19

Hallo
Ich habe ein problem mit einer Fehlermeldung

"Ungültige Konvertierung von Typ DBNull in Typ Boolean."

Ich habe in der DB/tabelle "Eintraege" eine Spalte vom Typ Boolean (Checkbox)
ist die Checkbox nicht gesetzt, also "False" soll die ganze Row eingefärbt werden,
das klappt auch soweit.
Wenn ich aber zur Laufzeit einen neuen Datensatz zufügen möchte steigt das Prog mit der Fehlermeldung
"Ungültige Konvertierung von Typ DBNull in Typ Boolean." aus.
Wie ist das möglich ?
Diese spalte kann ja nur 2 zustände haben. Entweder "True" oder "False"
Der code für cellformatting ist..

  Private Sub DGV_Eintraege_CellFormatting(sender As System.Object, e As _
    System.Windows.Forms.DataGridViewCellFormattingEventArgs) Handles _
    DGV_Eintraege.CellFormatting
        For i As Integer = 0 To DGV_Eintraege.Rows.Count - 1
 
            If CBool(DGV_Eintraege.Rows(i).Cells(9).Value) = False Then
                DGV_Eintraege.Rows(i).DefaultCellStyle.BackColor = Color.Lime
                DGV_Eintraege.Rows(i).DefaultCellStyle.ForeColor = Color.Black
            End If
 
        Next i
    End Sub
Ein neuer Datensatz soll ganz normal mit

   Private Sub btn_DS_anlegen_Click(sender As Object, e As EventArgs) Handles _
     btn_DS_anlegen.Click
        ' markiere_Pflichtfelder()
        Datensatz_Edit()
        EintraegeBindingSource.AddNew()
           End Sub
eingefügt werden. Also nichts ungewöhnliches.
wie gesagt. Die Fehlermeldung kommt direkt bei Click auf "Datensatz anlegen"
Wie könnte ich diesen Fehler abfangen bzw anders Programmieren.
Wäre schön wenn da jemand eine Lösung wüsste

Gruß
SA
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Fehlermeldung Cellformatting 
Autor: Manfred X
Datum: 02.03.19 14:42

Hallo!

Wenn Deine Boolean-Datenspalte Nullwerte erlaubt,
kann auch DBNull.value drinstehen - insbesondere
dann, wenn für diese Spalte kein Default-Wert festgelegt ist.

Du kannst die IsDBNull-Medthode verwenden, um solche
Werte in der Spalte zu übergehen.

In einer CellFormatting-Handler-Routine formatiert man
nur die aktuelle Zelle, sonst drohen Endlosschleifen o.ä.
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Fehlermeldung Cellformatting 
Autor: Kuno60
Datum: 02.03.19 14:52

Knabber schrieb:
Zitat:

Wenn ich aber zur Laufzeit einen neuen Datensatz zufügen
möchte steigt das Prog mit der Fehlermeldung
"Ungültige Konvertierung von Typ DBNull in Typ
Boolean." aus.
Wie ist das möglich ?

Hallo,

anscheinend hast du diese Spalte so eingestellt, dass Null-Werte zugelassen sind.
Du müsstest also auch noch prüfen, ob der Wert der Spalte DBNull ist.

Eine Schleife in einem CellFormatting-Ereignis ist falsch und macht das DGV langsam.
Das DGV ruft vor dem Zeichnen einer Zelle das CellFormatting-Ereignis auf. Damit hat man die Möglichkeit den Wert für die Anzeige anders zu formatieren und den CellStyle zu ändern.
Dieses Ereignis wird also für jede einzelne Zelle aufgerufen. Welche Zelle dieses Ereignis gerade aufruft, erfährst du mit e.RowIndex und e.ColumnIndex. Auch den CellStyle kannst du direkt über die e-Variable setzen.
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Fehlermeldung Cellformatting 
Autor: Knabber
Datum: 02.03.19 15:59

ok
da es ja nun grundsäzlich nicht richtig ist werde ich es ganz lassen
habe das cellformatting wieder entfernt.
Trotzdem war es für mich interressant zu erfahren warum die Fehlermeldung kam.

Im Dataset war die Spalte übrigens "AllowDBNull=False"

Vielen Dank für die Info
SA
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel