I hope not many people are using flat file with such kind of structure, but if you are then no worries now you don’t have to do any weird adjustments. J
I took some time to figure out what is going wrong here and why it is not working, and it caused some extra time to figure out all and I didn’t get paid for that extra time so you can understand my frustration!!!
But anyways here it goes,
Consider you have file which has data like
So if we see some of rows does not have entries for all columns (Row 2 and 3)
Now when you create Flat File Connection manager in SSIS and use this file as source
Column Delimiter: ~
Row Delimiter: |
Go columns and click on refresh so that changes take place you might get error:
TITLE: Microsoft Visual Studio
The last row in the sampled data is incomplete. The column or the row delimiter may be missing or the text is qualified incorrectly.
Also if you see preview will show only two rows and not all four rows
You just don’t see all result when you preview.
What went wrong?
Reason behind issue:
So we have Row delimiter and column delimiter.
Column Delimiter gets first preference and then Row delimiter.
Consider our file,
–14 Columns in all, so SSIS flat file connection manager expects 13 “|”
–In this row it finds only 11 “|” so it thinks row is not yet over and continues till it finds 2 more “|”, even if it encounters row delimiter while before it reaches two more “|” it will ignore that row delimiter
–Here it will append this row to previous row as it thinks previous row is incomplete and after two “|” once it reaches 13 “|” it will append everything else on this row till it finds row delimiter
–For this two rows everything is fine so it will be shown normally
So if I do preview with this file I will see
So this is not right…
What can be done?
Unfortunately nothing (other than using codeplex tool for flat file source) if you are on SQL 2005, SQl 2008 or SQL 2008 R2
We also have connect article which talks about this bug,
And solution is to use codeplex utility
However if you are on SQL 2012 be happy, as this bug is fixed in SQL Server data Tools with comes with SQl 2012
If you look at documentation for Flat File connection manager in SQL Server data Tools
By default, the Flat File connection manager always checks for a row delimiter in unquoted data, and starts a new row when a row delimiter is found. This enables the connection manager to correctly parse files with rows that are missing column fields.
In some cases, disabling this feature may improve package performance. You can disable this feature by setting the Flat File connection manager property, AlwaysCheckForRowDelimiters, to False.
This is not present in documentation till SQL 2008 R2 SSIS
I end this here!!!
Author : Dilkush(MSFT) SQL Developer Engineer, Microsoft
Reviewed by : Debarchan(MSFT) SQL Developer Engineer, Microsoft