vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Mails senden, abrufen und decodieren - ganz easy ;-)  
 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

ADO.NET / Datenbanken
SqlDataReader Problem 
Autor: shivan
Datum: 30.07.10 16:46

Hallo zusammen

Eigentlich habe ich das Ganze so programmiert, wie auch sonst immer, doch ich verstehe einfach nicht, wo ich einen Fehler mache. Deshalb dachte ich mir, dass mir vielleicht hier jemand weiterhelfen kann. Am SQL - String kann es jedoch nicht liegen, ich habe den direkt aus meiner manuell erstellten Abfrage kopiert.

 
    Public Function CeckPersonalNrExists() As Boolean
        Dim iPersonalNr As Integer
        Dim bCancel As Boolean
        Dim sSQL As String = ""
        Dim oCmd As SqlClient.SqlCommand
        Dim oRdr As SqlClient.SqlDataReader
 
        Try
            'Prüfen, ob die PersonalNr. in einen Integer konvertiert werden kann
            If ConvertPersonalNrToInteger(iPersonalNr) Then
                'Prüfen ob PersonalNr bereits exisitert
                sSQL = " SELECT COUNT(MitPersonalNr) AS Anzahl " & _
                       " FROM t_Mitarbeiter " & _
                       " WHERE MitPersonalNr = {0} "
                oCmd = g_oApp.ConnectionAppl.CreateCommand
                sSQL += String.Format(sSQL, iPersonalNr)
                oCmd.CommandText = sSQL
                oRdr = oCmd.ExecuteReader
 
                If oRdr.Read() Then
                    'Falls die Anzahl der geprüften PersonalNr. 0 ist, gibt die 
                    ' Funktion False
                    'zurück und die Validierung läuft weiter
 
                    If String.Format("{0}", oRdr.GetValue(0)) = 0 Then
                        Return False
                    Else
                        'Fehlermeldung
                        MessageBox.Show("Die Personalnummer " & _
                          txtPersonalNr.Text & " existiert bereits.", _
                        "Validierungsfehler", MessageBoxButtons.OK, _
                        MessageBoxIcon.Error)
                        txtPersonalNr.Focus()
                        txtPersonalNr.SelectAll()
                        Return True
 
                    End If
                End If
            Else
                Exit Function
            End If
 
        Catch ex As Exception
            MsgBox(ex)
        Finally
            'Reader schliessen
            Afi.GlobalFunctions.CloseDataReader(oRdr)
        End Try
    End Function
 
    Private Function ConvertPersonalNrToInteger(ByVal iPersonalNr As Integer) _
      As Boolean
        Try
            iPersonalNr = Convert.ToInt32(txtPersonalNr.Text)
            Return True
        Catch
            MessageBox.Show("Das Textfeld PersonalNr enthält einen zu grossen" & _
              "Wert." _
            , "Validierungsfehler", MessageBoxButtons.OK, MessageBoxIcon.Error)
            txtPersonalNr.Focus()
            txtPersonalNr.SelectAll()
        End Try
    End Function
Der Fehler tretet beim Ausführen folgender Zeile auf:

oRdr = oCmd.ExecuteReader
Fehlermeldung (erhalten durch MsgBox(ex) ):

Das Argument 'Promt' kann nicht in den Typ 'String' umgewandelt werden.

Weiss jemand, wo sich die Ursache meines Fehlers befindet? Bin für jede Hilfe dankbar.

Freundliche Grüsse

Shivan
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
SqlDataReader Problem1.660shivan30.07.10 16:46
Re: SqlDataReader Problem921ModeratorFZelle30.07.10 21:25
Re: SqlDataReader Problem865shivan02.08.10 14:05
Re: SqlDataReader Problem1.029ModeratorFZelle02.08.10 15:38
Re: SqlDataReader Problem903ModeratorDaveS31.07.10 07:31

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