Solved

String or binary data would be truncated

Posted on 2007-11-16
5
324 Views
Last Modified: 2008-03-06
Hello Everyone I get the following error message:

Microsoft OLE DB Provider for ODBC Drivers error '80040e57'

[Microsoft][ODBC SQL Server Driver][SQL Server]String or binary data would be truncated.

/OPICForms/115/save_sv.asp, line 163

Is this caused by my code or by the datatyeps in my database?
For instance, if I hava a string it's too long to fit in the database?
if it's caused by my code, please let me know and I'll include the code, it's just that this is 14 page application and the error seems to come from the UPDATE statmetn, which doesn't tell me anything:

      
      if sUpdate<> "" then

       sUpdate = "UPDATE " & sTable & " SET " & sUpdate & " [Part" & iFormPart & "Complete]=" & Request.Form("_complete") & ", [Part" & iFormPart & "Updated_ts]='" & now() & "' WHERE FK_ApplicationID=" & iApplicationID
      
      
      else
             sUpdate = "UPDATE " & sTable & " SET [Part" & iFormPart & "Complete]=" & Request.Form("_complete") & ", [Part" & iFormPart & "Updated_ts]='" & now() & "' WHERE FK_ApplicationID=" & iApplicationID
      end if

      objConn.execute(sUpdate)

end if


Any ideas?

Here is the UPDATE if I do response.write:

UPDATE tableName SET [chkFI]='1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0', [Technical1]=NULL, [Technical2]=NULL, [TrainingManagement]='0', [TrainingProfessional]='0', [TrainingLabor]='0', [EmployPolicy]=0, [Years]='0', [Managerial1]=NULL, [UnskilledLabor1]=NULL, [Managerial2]=NULL, [UnskilledLabor2]=NULL, [Partnerships]=0, [WomenBenefits]=0, [BenefitPoor]=0, [CompanyBenefits]=0, [DescribePartnerships1]=NULL, [DescribePartnerships2]=NULL, [DescribePartnerships3]=NULL, [DescribePartnerships4]=NULL, [chkbenefits]='0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0', [chkBenefitPoor]='0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0', [chkCompanyBenefits]='0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0', [chkEmployPolicy]='0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0', [chkWomenBenefits]='0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0', [chkPartnerships]='0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0', [Part09Complete]=0, [Part09Updated_ts]='11/16/2007 11:43:37 AM' WHERE FK_ApplicationID=995


It seems to have strange data like chkEmployPolicy = 0, is it because with several answers it sets up a string like this [chkCompanyBenefits]='0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0',

How do I fix somethign like this?

How can somethign like this happen, it's coming from the checkbox question, but why? why have the name equal to 0 rather than just 0
0
Comment
Question by:Gemini532
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
5 Comments
 
LVL 13

Expert Comment

by:samic400
ID: 20299939
Most of the time when I get this error, I am trying to put too much data into a field in my database that won't hold that much data.
0
 
LVL 13

Expert Comment

by:samic400
ID: 20299955
A solution that I use is I always trim my fields by using the mid function to only accept the maximum number of character allowed in my field in SQL Server.

So if you had a field in your table that only allowed 30 characters, just use the mid(myfield,1,30) to make sure you are only allowing the correct number of bytes.

Also, create maximum sizes on your form input fields so you won't all the user to exceed the entry there either.
0
 
LVL 13

Expert Comment

by:samic400
ID: 20299976
If you are using chexkboxes you need to test the results by a javascript like this to see what was selected in your checkboxes:

for (counter=0;counter<job_form.chkjob.length;counter++)
 {
   if (job_form.chkjob[counter].checked)
      {
       chkbox_choices = chkbox_choices + 1;
      }
}

It looks like you are bringing in all of your values for the form checkbox instead of the one you actually want, that is why you have so many numbers in your string.
0
 

Author Comment

by:Gemini532
ID: 20299995
but multiple checkboxes are checked, therefore there shoudl be mulitple values.. .no?
0
 
LVL 13

Accepted Solution

by:
samic400 earned 500 total points
ID: 20300017
On your processing form side, before you update, cycle through to see what was checked:

<%
for i = 1 to request.form("chkjob").count
     jobid = request.form("chkjob")(i)
next
%>

the field jobid will give you a specific value in the "array" of potential values for my checkboxes in the "chkjob" form field.
0

Featured Post

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Select record with the most recent date 14 71
Adding Row and Cell on a table 14 28
innerHTML 7 40
return false must be hit after calling certain command 10 45
I recently decide that I needed a way to make my pages scream on the net.   While searching around how I can accomplish this I stumbled across a great article that stated "minimize the server requests." I got to thinking, hey, I use more than one…
This demonstration started out as a follow up to some recently posted questions on the subject of logging in: http://www.experts-exchange.com/Programming/Languages/Scripting/JavaScript/Q_28634665.html and http://www.experts-exchange.com/Programming/…
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…
Exchange organizations may use the Journaling Agent of the Transport Service to archive messages going through Exchange. However, if the Transport Service is integrated with some email content management application (such as an antispam), the admini…

726 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question