Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Wie kann ich mit VBNet Daten in SQL Server einfügen

Es bedeutet, dass die Anzahl der in Ihren VALUES angegebenen Werte -Klausel auf dem INSERT -Anweisung ist nicht gleich der Gesamtzahl der Spalten in der Tabelle. Sie müssen den Spaltennamen angeben, wenn Sie nur versuchen, in ausgewählte Spalten einzufügen.

Ein weiterer, da Sie ADO.Net verwenden , Ihre Abfrage immer parametrisiert, um SQL Injection zu vermeiden . Was Sie gerade tun, ist, dass Sie besiegen die Verwendung von sqlCommand .

Bsp.

Dim query as String = String.Empty
query &= "INSERT INTO student (colName, colID, colPhone, "
query &= "                     colBranch, colCourse, coldblFee)  "
query &= "VALUES (@colName,@colID, @colPhone, @colBranch,@colCourse, @coldblFee)"

Using conn as New SqlConnection("connectionStringHere")
    Using comm As New SqlCommand()
        With comm
            .Connection = conn
            .CommandType = CommandType.Text
            .CommandText = query
            .Parameters.AddWithValue("@colName", strName)
            .Parameters.AddWithValue("@colID", strId)
            .Parameters.AddWithValue("@colPhone", strPhone)
            .Parameters.AddWithValue("@colBranch", strBranch)
            .Parameters.AddWithValue("@colCourse", strCourse)
            .Parameters.AddWithValue("@coldblFee", dblFee)
        End With
        Try
            conn.open()
            comm.ExecuteNonQuery()
        Catch(ex as SqlException)
            MessageBox.Show(ex.Message.ToString(), "Error Message")
        End Try
    End Using
End USing 

PS:Bitte ändern Sie die in der Abfrage angegebenen Spaltennamen in die in Ihrer Tabelle gefundene Originalspalte.