Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Come posso inserire dati in SQL Server utilizzando VBNet

Significa che il numero di valori specificato nel tuo VALUES clausola sul INSERT istruzione non è uguale al numero totale di colonne nella tabella. Devi specificare il nome della colonna se tenti di inserire solo su colonne selezionate.

Un altro, visto che stai usando ADO.Net , ha sempre parametrizzato la tua query per evitare SQL Injection . Quello che stai facendo in questo momento è che stai sconfitta l'uso di sqlCommand .

ex

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:cambia i nomi delle colonne specificati nella query nella colonna originale trovata nella tabella.