Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

Como posso inserir dados no SQL Server usando VBNet


Isso significa que o número de valores especificados em seu VALUES cláusula no INSERT instrução não é igual ao número total de colunas na tabela. Você deve especificar o nome da coluna se tentar inserir apenas nas colunas selecionadas.

Outro, já que você está usando o ADO.Net , sempre parametrizou sua consulta para evitar SQL Injection . O que você está fazendo agora é que você está derrotando o uso de 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:altere os nomes das colunas especificados na consulta para a coluna original encontrada em sua tabela.