Asked by:
text or binary data will be truncated error

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