locked
text or binary data will be truncated error RRS feed

  • Question

  • User-1633045945 posted

    Hello,

    i am trying to store an image in a sql database

    the column ("waste_signature") is set to varbinary(max)

    the data that I have to convert to byte() is the following:

    

    I use the following code to convert to Byte()... The arrparms(22) is an element in an array that holds the base64 string above

    Dim dataURI As String = arrparms(22) 
                    Dim split_1 As String() = dataURI.Split(";")
                    Dim split_2 As String = split_1(1).Replace("base64,", "").Replace("base64", "")
                    'Convert base64 to byte
                    Dim byteConvertedImage As Byte() = Convert.FromBase64String(split_2)

    Then I create the parameter for the sql insert
    objCommand.Parameters.Add("waste_signature", SqlDbType.VarBinary, 2147000000) objCommand.Parameters("waste_signature").Value = byteConvertedImage

    The problem is when the insert is executed an error is generated that shows that the binary data or string is too big and would be truncated
    and the statement has been terminated.

    So I need a little direction on which datatype I should be using and/or how I should be inserting the binary data into the database table.
    I have followed examples but have received the same error.
    Friday, November 17, 2017 5:54 AM

All replies

  • User991499041 posted

    Hi mstrsftwr,

    The problem is when the insert is executed an error is generated that shows that the binary data or string is too big and would be truncated 
    and the statement has been terminated.
    

    Please check all values when you get that exception in debugger. This error comes when you try to insert long data and database contain limited size. When there is mismatch between the passed-in column value from code and DB defined size of a column, you would generally get this issue.

    Regards,

    zxj

    Friday, November 17, 2017 6:38 AM
  • User364663285 posted

    HI,

    This is one column length problem and please try to increase your column length.

    Monday, November 20, 2017 5:28 AM
  • User347430248 posted

    Hi mstrsftwr,

    the cause for the error is ,"This error message appears when you try to insert a string with more characters than the column can maximal accommodate."

    solution:

    Errors of the Severity Level 16 are generated by the user and can be fixed by the SQL Server user. The statement cannot be executed this way. You must either shorten the string to be isnerted to widen the column.

    example to reproduce the issue:

    USE tempdb;
    IF OBJECT_ID(‘tempdb.#t’) > 0
     DROP TABLE #t
    GO
    CREATE TABLE #t
    (
     c1 CHAR
    );
    INSERT INTO #t SELECT ‘abc’
    GO

    In the above example we try to insert a string ‘abc’ with a length of 3 into the column c1 of the table #t. Because c1 is of the data type CHAR(1), the error is raised.

    Reference:

    String or binary data would be truncated.

    Regards

    Deepak

    Monday, November 20, 2017 6:14 AM