0

このコード ブロックに問題があります。エラーは次のとおりです。文字列またはバイナリ データが切り捨てられます

    Protected Sub FormView1_ItemInserting(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.FormViewInsertEventArgs) Handles FormView1.ItemInserting
    Using cnnentry As New SqlConnection("Data Source=NB-1492\sqlipt;Initial Catalog=Bookings;Integrated Security=True;Pooling=False")
        Dim entrclientid As String
        Dim clid As New TextBox
        clid = FormView1.FindControl("txtclientid")
        entrclientid = clid.Text
        Dim sql As String = "INSERT INTO BOOKING_DETAILS(CLIENT_ID,BOOKING_DATE,REGO,CHECK_IN_DATE,CHECK_OUT_DATE,ROOM_ID) VALUES(@ROOM_ID,@CHECK_OUT_DATE,@CHECK_IN_DATE,@CLIENT_ID,@BOOKING_DATE,@REGO)"
        Dim cmdentry As New SqlCommand(sql, cnnentry)
        cmdentry.Parameters.AddWithValue("@CLIENT_ID", clid.Text)

        Dim curdate As New TextBox
        curdate = FormView1.FindControl("txtdate")
        cmdentry.Parameters.AddWithValue("@BOOKING_DATE", curdate.Text)

        Dim rego As New TextBox
        rego = FormView1.FindControl("RegoTextBox")
        cmdentry.Parameters.AddWithValue("@REGO", rego.Text)

        Dim textin As New TextBox
        textin = FormView1.FindControl("textcheckin")
        cmdentry.Parameters.AddWithValue("@CHECK_IN_DATE", textin.Text)

        Dim textout As New TextBox
        textout = FormView1.FindControl("textcheckout")
        cmdentry.Parameters.AddWithValue("@CHECK_OUT_DATE", textout.Text)

        Dim txtroomid As New TextBox
        txtroomid = Session.Item("room_tpe")
        cmdentry.Parameters.AddWithValue("@ROOM_ID", roomtype.Text)

        cnnentry.Open()
        strclid = cmdentry.ExecuteNonQuery()
        cnnentry.Close()
    End Using
End Sub

このエラーが発生する理由を誰かが説明できますか?

テーブルのデータ型は次のとおりです。 Booking_ID int
Room_ID int
Check_In_Date nvarchar(MAX)
Check_Out_Date nvarchar(MAX)
Booking_Date nvarchar(MAX)
Client_ID nchar(11) Rego nvarchar(6)
Room_Cost money

前もって感謝します

4

1 に答える 1

0

定義されたデータ型では保持できないフィールドにデータを挿入しようとしています。例: VARCHAR(3) は「TestData」を保持できません。

テーブル BOOKING_DETAILS で、列のデータ型を確認します。

于 2013-09-16T09:13:47.660 に答える