SSIS: DTS_E_INDUCEDTRANSFORMFAILUREONERROR error after upgrading to SQL 2019

Vivek Devalkar 122 Reputation points
2021-03-01T22:16:41.03+00:00

We have a SSIS package that extracts data from a MySQL DB view and loads it into a SQL Server table. This has been working fine for a couple of years now on SQL Server 2017. After we've upgraded to SQL Server 2019 though, it has started to give DTS_E_INDUCEDTRANSFORMFAILUREONERROR errors.

Actual error messages are in the below screenshot.

73201-image.png

I've tried to debug and simplify the problem statement and finally figured the following 2 scenarios.

If I setup the ODBC Source step with the query below then it doesn't work.
select customer_id , customer_name from bi.customer;

If I set it up as the one below, it works.
select customer_id, CONVERT(customer_name, char(60)) as customer_name from bi.customer;

This if of course just a sample query so I don't want to go and change all packages like this.

Would like to know if anyone has any idea why this is happening and if there is a more standard solution to ensure we don't have to do all these changes to all packages.

UPDATE 3/3:
I was able to isolate this down to one row and column and it looks like something to do with special characters.
The value in question is as shown below
73836-image.png

I basically tried to insert 1000 rows at a time and it initially worked but started to fail within a certain range. I further narrowed down the rows loaded and was able to identify a specific row where the package was failing (there may be more such rows/columns but this was the first instance) and when i try to insert just that row it fails.
Specifically, when I include the street column shown above it fails and it loads fine if I do not include that column.

SQL Server Integration Services
SQL Server Integration Services
A Microsoft platform for building enterprise-level data integration and data transformations solutions.
2,626 questions
0 comments No comments
{count} votes

3 answers

Sort by: Most helpful
  1. Monalv-MSFT 5,901 Reputation points
    2021-03-02T06:53:11.54+00:00

    Hi @Vivek Devalkar ,

    1.Please change the data type of the column in the external source.

    2.Or we can use Data Conversion Transformation to change the data type of the column.

    Best regards,
    Mona


    If the answer is helpful, please click "Accept Answer" and upvote it.

    Note: Please follow the steps in our documentation to enable e-mail notifications if you want to receive the related email notification for this thread.


  2. Yitzhak Khabinsky 26,296 Reputation points
    2021-03-03T16:23:00.81+00:00

    @Vivek Devalkar ,

    Due to your latest discovery, I would suggest to change SQL Server DB column from data type varchar(180) to NVARCHAR(180) to accomodate accented characters.


  3. Satish Chelluri 0 Reputation points
    2025-01-11T23:07:37.7666667+00:00

    I found that after altering the column length of the 'Premium' field, which has a numeric data type, the package executed successfully without any issues when fetching data from the Oracle source.

    0 comments No comments

Your answer

Answers can be marked as Accepted Answers by the question author, which helps users to know the answer solved the author's problem.