?
Solved

DTS Conversion Problem w/ActiveX Script

Posted on 2007-12-04
6
Medium Priority
?
374 Views
Last Modified: 2013-11-30
I have the following code. The problem is that the source cell (BTN) can be either empty (NULL), be a number formatted as text, or be stored as a number. When I run the transformation, it sees any row that has a number, stored as a number, as NULL and will not import it. I have tried using CStr() around the source value, but that does not seem to help. Any ideas?
Function Main()
	If IsNull(DTSSource("BTN")) Then
	    Main = DTSTransformStat_SkipRow
	    Exit Function
	ElseIf IsNumeric(DTSSource("BTN")) Then
	    DTSDestination("BTN") = CDbl(DTSSource("BTN"))
	End If
	DTSDestination("RequestID") = DTSSource("RqstID")
	Main = DTSTransformStat_OK
End Function

Open in new window

0
Comment
Question by:dbbishop
  • 3
  • 3
6 Comments
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 20404861
Assuming this is a text file, please post some sample data that presents that problem.
0
 
LVL 15

Author Comment

by:dbbishop
ID: 20406107
I am importing two columns on the worksheet. The column represented as BTN is either a 10 or 13-digit number. On the worksheet, some of the colums are represented as number formatted as text, some are text (e.g. preceeded by an apostrophe "'") which is ignored by DTS, and some are actually sotred as numbers in a numeric format.

I have one file that only had about 40 rows, so I put a msgbox ahead of the If...Then...Else statement to show the value. With those that had the data in the cell in a numeric format, then MsgBox(DTSSource("BTN")) showed a value of NULL.
0
 
LVL 15

Author Comment

by:dbbishop
ID: 20406113
btw, I am importing from a sheet in an Excel workbook.
0
Learn to develop an Android App

Want to increase your earning potential in 2018? Pad your resume with app building experience. Learn how with this hands-on course.

 
LVL 75

Accepted Solution

by:
Anthony Perkins earned 750 total points
ID: 20408370
Than this should help:
Excel Inserts Null Values
http://www.sqldts.com/254.aspx
0
 
LVL 15

Author Comment

by:dbbishop
ID: 20416073
acperkins: I tried the example they showed by using an ActiveX script and that does not appear to help with the problem. One thing is that there can be a datatype change within the first eight rows.

The user sends me data that i copy/paste into a template spreadsheet and then run a DTS package that does a return-trip process (imports the data, runs an EXECUTE SQL task to pull data from other tables, then exports the data back to another sheet in the workbook.

I've advised the user to make sure all data is formatted as text, and I've started eyeballing it before running the package (which is basically fix #1 of the article), so I will just continue to go that route, although it would be nice if the script handled the problem.

Doug
0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 20416663
>>I tried the example they showed by using an ActiveX script and that does not appear to help with the problem. <<
This is exactly what we use.  So if it does not work for you, than I am afraid I have no idea.

Good luck.
0

Featured Post

Hire Technology Freelancers with Gigs

Work with freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely, and get projects done right.

Question has a verified solution.

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

What if you have to shut down the entire Citrix infrastructure for hardware maintenance, software upgrades or "the unknown"? I developed this plan for "the unknown" and hope that it helps you as well. This article explains how to properly shut down …
This shares a stored procedure to retrieve permissions for a given user on the current database or across all databases on a server.
Using examples as well as descriptions, and references to Books Online, show the documentation available for datatypes, explain the available data types and show how data can be passed into and out of variables.
Viewers will learn how to use the UPDATE and DELETE statements to change or remove existing data from their tables. Make a table: Update a specific column given a specific row using the UPDATE statement: Remove a set of values using the DELETE s…
Suggested Courses

601 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